/* ============================================
   Chat Module
   ============================================ */

input,
textarea,
[contenteditable="true"],
.story-content,
.chapter-content,
.book-page-content,
.message-text,
p,
span.selectable,
.selectable {
    user-select: text;
    -webkit-user-select: text;
    -moz-user-select: text;
    -ms-user-select: text;
}

.chat-popup {
    position: fixed;
    bottom: 24px;
    right: 24px;
    /* Nav-Leiste (.chat-navigation-section) + Kontaktliste (.chat-sidebar) für kollabierte Breite */
    --kinma-chat-nav-rail-width: 64px;
    --kinma-chat-sidebar-width: 280px;
    --kinma-chat-collapsed-total-width: calc(var(--kinma-chat-nav-rail-width) + var(--kinma-chat-sidebar-width));
    --kinma-chat-vertical-tabs-extra-w: 0px;
    width: 1000px !important;
    height: 600px !important;
    min-width: 1000px !important;
    min-height: 600px !important;
    max-width: 1000px !important;
    max-height: 600px !important;
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
    display: none;
    flex-direction: column;
    z-index: 2000;
    overflow: hidden;
    transition: none; /* Desktop-Expand: siehe .chat-popup.active (nicht beim Ziehen/Resize) */
    resize: none !important; /* Disable resize */
    will-change: transform;
    contain: layout style;
}

.chat-popup.active {
    display: flex;
}

/*
 * Nav-Inseln, Flyouts und Tooltips über der Chatbox (.kinma-chat-popup-instance-active = 100004).
 * Unter Minimize-Animation (100010), über normalem Chat-Fenster.
 */
body:has(.chat-popup.active:not(.chat-popup-mobile-fullscreen)) .left-nav-cluster {
    z-index: 100011 !important;
}

body:has(.chat-popup.active:not(.chat-popup-mobile-fullscreen)) .left-nav-cluster .nav-extras-hover-zone,
body:has(.chat-popup.active:not(.chat-popup-mobile-fullscreen)) .left-nav-cluster .nav-extras-flyout-island,
body:has(.chat-popup.active:not(.chat-popup-mobile-fullscreen)) .left-nav-cluster .nav-submenu,
body:has(.chat-popup.active:not(.chat-popup-mobile-fullscreen)) .left-nav-cluster .utility-label {
    z-index: 100012;
}

body:has(.chat-popup.active:not(.chat-popup-mobile-fullscreen)) .nav-floating-tooltip {
    z-index: 100013 !important;
}

/*
 * Desktop: nur box-shadow weich (Maximieren/Restore); Größe/Position ohne Transition (weniger Reflow-Lag).
 */
.chat-popup.active:not(.chat-popup-mobile-fullscreen):not(.chat-popup--resizing):not(.kinma-chat-popup--docked-float):not(.kinma-chat-popup-flip-anim) {
    transition-property: box-shadow;
    transition-duration: 0.32s;
    transition-timing-function: cubic-bezier(0.32, 0.72, 0, 1);
}

.chat-popup.active.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen),
.chat-popup.active.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen),
.chat-popup.active.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen) {
    box-shadow: none !important;
}

/* Resize: keine CSS-Transition (sonst hinterher der Maus) */
.chat-popup.active.chat-popup--resizing:not(.chat-popup-mobile-fullscreen):not(.chat-popup-header-dbl-fullscreen):not(.kinma-chat-popup--docked-float),
.chat-popup.chat-popup--resizing:not(.chat-popup-mobile-fullscreen) {
    transition: none !important;
}

/* Beim Ziehen: Tab-Leiste nicht pro Frame neu animieren (viele Tabs = weniger Lag) */
.chat-popup.chat-popup--resizing .chat-popup-window-tab,
.chat-popup.chat-popup--resizing .chat-popup-window-tab-inner,
.chat-popup.chat-popup--resizing .chat-popup-window-tab-label,
.chat-popup.chat-popup--resizing .chat-popup-window-tab-leading,
.chat-popup.chat-popup--resizing .chat-popup-header-tabs-inner {
    transition: none !important;
}

/* Seiten-Snap: volle Dock-Höhe (nicht durch 96vh von .chat-popup--user-layout begrenzt) */
.chat-popup.active.kinma-chat-popup--wall-snapped.kinma-chat-popup-layout-pinned:not(
        .chat-popup-mobile-fullscreen
    ):not(.kinma-chat-popup--docked-float) {
    border-radius: 0 !important;
}

/* Wand-Snap + manuelles Resize: äußere Karte nie wieder 16px, Nav-Ecken ohne Transition */
.chat-popup.active.kinma-chat-popup--wall-snapped.chat-popup--resizing:not(.chat-popup-mobile-fullscreen),
.chat-popup.kinma-chat-popup--wall-snapped.chat-popup--resizing:not(.chat-popup-mobile-fullscreen) {
    border-radius: 0 !important;
    box-shadow: none !important;
}

.chat-popup.kinma-chat-popup--wall-snapped.chat-popup--resizing:not(.chat-popup-mobile-fullscreen)
    .chat-nav-rail-front,
.chat-popup.kinma-chat-popup--wall-snapped.chat-popup--resizing:not(.chat-popup-mobile-fullscreen)
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped.chat-popup--resizing:not(.chat-popup-mobile-fullscreen)
    .chat-popup-body {
    transition: none !important;
}

/* Layout-Animation: Pin-Geometrie schlägt .chat-popup--user-layout width/height !important */
.chat-popup.active.kinma-chat-popup-layout-pinned:not(.chat-popup-mobile-fullscreen):not(.kinma-chat-popup--docked-float) {
    left: var(--kinma-layout-pin-l) !important;
    top: var(--kinma-layout-pin-t) !important;
    right: auto !important;
    bottom: auto !important;
    width: var(--kinma-layout-pin-w) !important;
    height: var(--kinma-layout-pin-h) !important;
    max-width: var(--kinma-layout-pin-w) !important;
    max-height: var(--kinma-layout-pin-h) !important;
    min-width: 0 !important;
    min-height: 0 !important;
    box-sizing: border-box !important;
}

/* Maximize / Restore: FLIP nur über transform (kein Springen durch width/left-Transition) */
.chat-popup.active.kinma-chat-popup-flip-anim:not(.chat-popup-mobile-fullscreen):not(.kinma-chat-popup--docked-float) {
    transition:
        transform 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        border-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        box-shadow 0.32s cubic-bezier(0.32, 0.72, 0, 1) !important;
    will-change: transform, border-radius;
}

/* Desktop: Minimize (_) — Genie-ähnlich zum Chat-Button in der linken Nav */
html.kinma-chat-minimize-genie-active {
    perspective: 1400px;
}

/* .active + 4 Klassen: schlägt .active.kinma-chat-popup-flip-anim (nur 0,28s Layout-FLIP) */
.chat-popup.active.kinma-chat-popup-minimize-anim:not(.chat-popup-mobile-fullscreen) {
    overflow: hidden !important;
    transition:
        transform 0.52s cubic-bezier(0.36, 0.04, 0.48, 1),
        border-radius 0.52s cubic-bezier(0.36, 0.04, 0.48, 1),
        box-shadow 0.4s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.28s cubic-bezier(0.4, 0, 0.2, 1) 0.1s !important;
    will-change: transform, opacity, border-radius;
    pointer-events: none !important;
    z-index: 100010 !important;
}

/* Aus Snap/Vollbild per Header-Zug: Transform per JS, nicht während Genie Öffnen/Schließen */
.chat-popup.active.kinma-chat-popup-minimize-anim.kinma-chat-popup-genie-drag-out:not(.chat-popup-mobile-fullscreen):not(
        .kinma-chat-popup-genie-open
    ):not(.kinma-chat-popup-genie-close) {
    pointer-events: auto !important;
    transition: none !important;
}

/* Während Minimize: Header / vertikale Tab-Leiste ziehbar → Animation abbrechen, nicht festkleben */
.chat-popup.active.kinma-chat-popup-minimize-anim:not(.chat-popup-mobile-fullscreen) .chat-popup-header,
.chat-popup.active.kinma-chat-popup-minimize-anim:not(.chat-popup-mobile-fullscreen)
    .chat-popup-header-drag-handle,
.chat-popup.active.kinma-chat-popup-minimize-anim:not(.chat-popup-mobile-fullscreen)
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active {
    pointer-events: auto !important;
    cursor: grab;
}

/* Öffnen (Genie aus Nav-Button): exakt Schließen rückwärts (gleiche Kurven, Opacity früher) */
.chat-popup.active.kinma-chat-popup-minimize-anim.kinma-chat-popup-genie-open:not(.chat-popup-mobile-fullscreen) {
    pointer-events: auto !important;
    transition:
        transform 0.52s cubic-bezier(0.36, 0.04, 0.48, 1),
        border-radius 0.52s cubic-bezier(0.36, 0.04, 0.48, 1),
        box-shadow 0.38s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1) 0s !important;
}

/* Schließen (Genie zum Nav-Button): Fenster → Pill, gleiche Kurven */
.chat-popup.active.kinma-chat-popup-minimize-anim.kinma-chat-popup-genie-close:not(.chat-popup-mobile-fullscreen) {
    transition:
        transform 0.52s cubic-bezier(0.36, 0.04, 0.48, 1),
        border-radius 0.52s cubic-bezier(0.36, 0.04, 0.48, 1),
        box-shadow 0.38s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.3s cubic-bezier(0.4, 0, 0.2, 1) 0.14s !important;
}

/* Legacy Flip-Minimize (nicht Genie): volle Deckkraft */
.chat-popup.active.kinma-chat-popup-minimize-anim.kinma-chat-popup-flip-anim:not(.chat-popup-mobile-fullscreen):not(.kinma-chat-popup-genie-open):not(.kinma-chat-popup-genie-close) {
    opacity: 1;
}

@keyframes kinmaChatDockPulse {
    0% {
        transform: scale(1);
    }
    40% {
        transform: scale(1.14);
    }
    100% {
        transform: scale(1);
    }
}

#chatUtilityBtn.kinma-chat-dock-pulse,
.utility-btn#chatUtilityBtn.kinma-chat-dock-pulse,
#supportControlsDesktop.kinma-chat-dock-pulse,
.nav-item.ai-chat-btn.kinma-chat-dock-pulse {
    animation: kinmaChatDockPulse 0.38s cubic-bezier(0.34, 1.4, 0.64, 1);
}

/* Nur beim Öffnen eines Kontakts: kurze Breiten-Animation (nicht während Nachrichten-Render) */
.chat-popup.kinma-chat-opening-contact.active:not(.chat-popup-mobile-fullscreen):not(.chat-popup--user-layout):not(.chat-popup--resizing) {
    transition:
        width 0.22s cubic-bezier(0.25, 0.8, 0.25, 1),
        max-width 0.22s cubic-bezier(0.25, 0.8, 0.25, 1),
        left 0.22s cubic-bezier(0.25, 0.8, 0.25, 1) !important;
}

@media (prefers-reduced-motion: reduce) {
    .chat-popup.active:not(.chat-popup-mobile-fullscreen):not(.chat-popup--resizing):not(.chat-popup-header-dbl-fullscreen):not(.kinma-chat-popup--docked-float):not(.kinma-chat-popup-flip-anim),
    .chat-popup.active.chat-popup--resizing:not(.chat-popup-mobile-fullscreen),
    .chat-popup.active.kinma-chat-popup-flip-anim:not(.chat-popup-mobile-fullscreen),
    .chat-popup.active.kinma-chat-popup-minimize-anim:not(.chat-popup-mobile-fullscreen) {
        transition: none !important;
    }

    #chatUtilityBtn.kinma-chat-dock-pulse,
    .utility-btn#chatUtilityBtn.kinma-chat-dock-pulse {
        animation: none !important;
    }
}

.chat-popup.kinma-chat-popup-clone {
    z-index: 100003;
}

.chat-popup.kinma-chat-popup-instance-active {
    z-index: 100004;
}

body.kinma-chat-embed {
    margin: 0;
    overflow: hidden;
    background: #111;
}

body.kinma-chat-embed .chat-popup.kinma-chat-embed-window {
    position: fixed !important;
    inset: 0 !important;
    width: auto !important;
    height: auto !important;
    max-width: none !important;
    max-height: none !important;
    min-width: 0 !important;
    min-height: 0 !important;
    border-radius: 16px;
    box-shadow: 0 16px 42px rgba(0, 0, 0, 0.42);
}

.chat-popup.has-profile-open:not(.chat-popup-mobile-fullscreen) {
    width: 1320px !important; /* 1000px + 320px */
}

/* Desktop: nur Nav + Kontaktliste, wenn keine Konversation aktiv (nicht gegen min-width:1000 der Basis) */
.chat-popup:not(.has-active-contact):not(.chat-popup-mobile-fullscreen):not(.chat-popup--user-layout) {
    width: min(
        calc(var(--kinma-chat-collapsed-total-width) + var(--kinma-chat-vertical-tabs-extra-w, 0px)),
        calc(100vw - 16px)
    ) !important;
    min-width: 0 !important;
    max-width: min(90vw, calc(100vw - 16px)) !important;
}

/* Volle Chatbreite nur mit geöffneter Konversation (sonst überschreibt diese Regel die schmale Breite) */
.chat-popup.active.has-active-contact:not(.chat-popup-mobile-fullscreen):not(.view-calls):not(.view-stories):not(.view-new-contacts):not(.view-settings):not(.chat-popup--user-layout) {
    width: calc(1000px + var(--kinma-chat-vertical-tabs-extra-w, 0px)) !important;
    min-width: calc(1000px + var(--kinma-chat-vertical-tabs-extra-w, 0px)) !important;
    max-width: 90vw !important;
}

/* Vertikale Tabs ohne Kontakt: schmale Breite (Tabs + Nav + Liste), kein leerer Chat-Hauptbereich */
.chat-popup.active.chat-popup--header-tabs-vertical:not(.has-active-contact):not(.chat-popup-mobile-fullscreen):not(
        .chat-popup--user-layout
    ) {
    width: min(
        calc(var(--kinma-chat-collapsed-total-width) + var(--kinma-chat-vertical-tabs-extra-w, 0px)),
        calc(100vw - 16px)
    ) !important;
    min-width: 0 !important;
    max-width: min(90vw, calc(100vw - 16px)) !important;
}

.chat-popup.chat-popup--user-layout.chat-popup--header-tabs-vertical:not(.has-active-contact):not(
        .chat-popup-mobile-fullscreen
    ) {
    min-width: min(
        calc(var(--kinma-chat-collapsed-total-width) + var(--kinma-chat-vertical-tabs-extra-w, 0px)),
        calc(100vw - 16px)
    ) !important;
}

/* Standort teilen: nur in mobiler Vollbild-Chat-Ansicht (siehe isChatLocationSharingAllowed) */
.chat-popup.active:not(.chat-popup-mobile-fullscreen) [data-chat-location-mobile-only='true'] {
    display: none !important;
}

/* KI-Modus mobil: kein Standort teilen */
.chat-popup.active.ai-mode.chat-popup-mobile-fullscreen [data-chat-location-mobile-only='true'] {
    display: none !important;
}

/* Frei skalierbare Chatbox: Größe per CSS-Variablen (gesetzt nach Nutzer-Resize) */
.chat-popup.chat-popup--user-layout:not(.chat-popup-mobile-fullscreen):not(.kinma-chat-popup--wall-snapped) {
    width: var(--kinma-chat-w, 1000px) !important;
    height: var(--kinma-chat-h, 600px) !important;
    min-width: min(
        calc(var(--kinma-chat-min-w, 1000px) + var(--kinma-chat-vertical-tabs-extra-w, 0px)),
        calc(100vw - 16px)
    ) !important;
    min-height: min(var(--kinma-chat-min-h, 1000px), calc(100vh - 16px)) !important;
    max-width: min(96vw, calc(100vw - 16px)) !important;
    max-height: min(96vh, calc(100vh - 16px)) !important;
}

/* Wand-Snap: volle Dock-Höhe, kein 96vh-Cap (sonst schwarze Lücke unten beim bottom-Resize) */
.chat-popup.active.kinma-chat-popup--wall-snapped.chat-popup--user-layout:not(.chat-popup-mobile-fullscreen),
.chat-popup.active.kinma-chat-popup--wall-snapped.chat-popup--resizing:not(.chat-popup-mobile-fullscreen) {
    width: var(--kinma-chat-w, 1000px) !important;
    height: var(--kinma-chat-h, 600px) !important;
    min-width: min(
        calc(var(--kinma-chat-min-w, 1000px) + var(--kinma-chat-vertical-tabs-extra-w, 0px)),
        calc(100vw - 16px)
    ) !important;
    min-height: 0 !important;
    max-width: min(96vw, calc(100vw - 16px)) !important;
    max-height: none !important;
}

.chat-popup.chat-popup--user-layout.has-profile-open:not(.chat-popup-mobile-fullscreen) {
    width: calc(var(--kinma-chat-w, 1000px) + 320px) !important;
    min-width: min(
        calc(var(--kinma-chat-min-w, 1000px) + var(--kinma-chat-vertical-tabs-extra-w, 0px) + 320px),
        calc(100vw - 16px)
    ) !important;
    max-width: min(96vw, calc(100vw - 16px)) !important;
}

.chat-popup.chat-popup--resizing:not(.chat-popup-mobile-fullscreen) {
    user-select: none;
}

.chat-popup-resize-handles {
    display: none;
    position: absolute;
    inset: 0;
    z-index: 10060;
    pointer-events: none;
    box-sizing: border-box;
    isolation: isolate;
}

.chat-popup.active:not(.chat-popup-mobile-fullscreen):not(.kinma-chat-popup-minimize-anim):not(
        .chat-popup-header-dbl-fullscreen
    ):not(.chat-popup-maximizing):not(.kinma-chat-popup--wall-snapped) .chat-popup-resize-handles {
    display: block;
}

/* Maximiert / FLIP-Maximize: keine Resize-Griffe; Wand-Snap: nur freie Kanten (siehe unten) */
.chat-popup.active.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) .chat-popup-resize-handles,
.chat-popup.active.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen) .chat-popup-resize-handles,
.chat-popup.kinma-chat-popup-minimize-anim .chat-popup-resize-handles {
    display: none !important;
    pointer-events: none !important;
}

/* Wand-Snap: Griffe an nicht angedockten Kanten/Ecken */
.chat-popup.active.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen):not(.chat-popup-maximizing):not(
        .chat-popup-header-dbl-fullscreen
    )
    .chat-popup-resize-handles {
    display: block !important;
}

.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='left'] .chat-popup-resize-handle--w,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='left'] .chat-popup-resize-handle--nw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='left'] .chat-popup-resize-handle--sw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='right'] .chat-popup-resize-handle--e,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='right'] .chat-popup-resize-handle--ne,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='right'] .chat-popup-resize-handle--se,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top'] .chat-popup-resize-handle--n,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top'] .chat-popup-resize-handle--nw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top'] .chat-popup-resize-handle--ne,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom'] .chat-popup-resize-handle--s,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom'] .chat-popup-resize-handle--sw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom'] .chat-popup-resize-handle--se,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-left'] .chat-popup-resize-handle--n,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-left'] .chat-popup-resize-handle--w,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-left'] .chat-popup-resize-handle--nw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-left'] .chat-popup-resize-handle--ne,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-left'] .chat-popup-resize-handle--sw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-right'] .chat-popup-resize-handle--n,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-right'] .chat-popup-resize-handle--e,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-right'] .chat-popup-resize-handle--nw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-right'] .chat-popup-resize-handle--ne,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='top-right'] .chat-popup-resize-handle--se,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-left'] .chat-popup-resize-handle--s,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-left'] .chat-popup-resize-handle--w,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-left'] .chat-popup-resize-handle--sw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-left'] .chat-popup-resize-handle--nw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-left'] .chat-popup-resize-handle--se,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-right'] .chat-popup-resize-handle--s,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-right'] .chat-popup-resize-handle--e,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-right'] .chat-popup-resize-handle--sw,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-right'] .chat-popup-resize-handle--ne,
.chat-popup.active.kinma-chat-popup--wall-snapped[data-kinma-wall-snap-zone='bottom-right'] .chat-popup-resize-handle--se {
    display: none !important;
    pointer-events: none !important;
}

.chat-popup-header,
.chat-popup-body,
.chat-popup #callStatusBar {
    position: relative;
    z-index: 1;
}

.chat-popup-resize-handle {
    position: absolute;
    pointer-events: auto !important;
    background: transparent;
    z-index: 3;
    touch-action: none;
}

/* Kanten */
.chat-popup-resize-handle--n {
    top: 0;
    left: 8px;
    right: 8px;
    height: 12px;
    cursor: ns-resize;
}

.chat-popup-resize-handle--s {
    bottom: 0;
    left: 8px;
    right: 8px;
    height: 12px;
    cursor: ns-resize;
}

.chat-popup-resize-handle--e {
    right: 0;
    top: 8px;
    bottom: 8px;
    width: 12px;
    cursor: ew-resize;
}

.chat-popup-resize-handle--w {
    left: 0;
    top: 8px;
    bottom: 8px;
    width: 12px;
    cursor: ew-resize;
}

/*
 * Vertikale Tabs: nur die äußerste linke Fensterkante (schmaler Streifen),
 * nicht die ganze Tab-Leiste — Tabs bleiben voll klickbar.
 */
.chat-popup.chat-popup--header-tabs-vertical:not(.chat-popup--header-tabs-disabled)
    .chat-popup-resize-handle--w {
    left: 0;
    width: 14px;
    top: 8px;
    bottom: 8px;
    z-index: 10065;
}

.chat-popup.chat-popup--header-tabs-vertical:not(.chat-popup--header-tabs-disabled)
    .chat-popup-resize-handle--nw,
.chat-popup.chat-popup--header-tabs-vertical:not(.chat-popup--header-tabs-disabled)
    .chat-popup-resize-handle--sw {
    left: 0;
    width: 18px;
    height: 18px;
    z-index: 10065;
}

/* Ecken */
.chat-popup-resize-handle--nw {
    top: 0;
    left: 0;
    width: 18px;
    height: 18px;
    cursor: nwse-resize;
}

.chat-popup-resize-handle--ne {
    top: 0;
    right: 0;
    width: 18px;
    height: 18px;
    cursor: nesw-resize;
}

.chat-popup-resize-handle--sw {
    bottom: 0;
    left: 0;
    width: 18px;
    height: 18px;
    cursor: nesw-resize;
}

.chat-popup-resize-handle--se {
    bottom: 0;
    right: 0;
    width: 18px;
    height: 18px;
    cursor: nwse-resize;
}

.chat-popup-header {
    background: #1a1a1a;
    color: #ffffff;
    padding: 0;
    display: flex;
    flex-wrap: nowrap;
    align-items: stretch;
    gap: 0;
    cursor: move;
    user-select: none;
    transition: none;
    min-height: 48px;
    position: relative;
    --kinma-chat-header-tab-fade: #1a1a1a;
}

/*
 * Desktop maximize: 24px Abstand links (wie .left-nav-cluster) + 24px zwischen Nav-Insel und Chatbox.
 * --kinma-chat-fs-left wird per JS aus .left-nav-cluster gemessen (Fallback ohne JS unten).
 * Variablen auch während .chat-popup-maximizing (gleiche Echen-Animation wie nach Abschluss).
 */
.chat-popup.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen),
.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) {
    --kinma-chat-inner-nav-radius: 24px;
    --kinma-chat-nav-island-bg: #1a1a1a;
}

.chat-popup.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen) {
    border-radius: 0 !important;
    transition:
        border-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        box-shadow 0.32s cubic-bezier(0.32, 0.72, 0, 1);
}

.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) {
    --kinma-chat-fs-gutter-bg: #1a1a1a;
    --kinma-chat-fs-right: env(safe-area-inset-right, 0px);
    --kinma-chat-fs-top: env(safe-area-inset-top, 0px);
    --kinma-chat-fs-bottom: env(safe-area-inset-bottom, 0px);
    left: var(
        --kinma-chat-fs-left,
        calc(24px + 3.75em + 24px + env(safe-area-inset-left, 0px))
    ) !important;
    top: var(--kinma-chat-fs-top) !important;
    right: var(--kinma-chat-fs-right) !important;
    bottom: var(--kinma-chat-fs-bottom) !important;
    width: auto !important;
    height: auto !important;
    /* Falls ein späteres Stylesheet .chat-popup--user-layout mit fester width setzt: nicht über den Viewport hinaus */
    max-width: calc(100vw - var(--kinma-chat-fs-left) - var(--kinma-chat-fs-right)) !important;
    max-height: calc(100vh - var(--kinma-chat-fs-top) - var(--kinma-chat-fs-bottom)) !important;
    min-width: 0 !important;
    min-height: 0 !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
}

.chat-popup.chat-popup-header-dbl-fullscreen.ai-mode:not(.chat-popup-mobile-fullscreen) {
    --kinma-chat-fs-gutter-bg: #4f46e5;
}

.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen) {
    --kinma-chat-inner-nav-radius: 24px;
    --kinma-chat-nav-island-bg: #1a1a1a;
}

/* KI-Modus: dunkle Back-Leiste hinter weißer Nav = KI-Lila (wie Header / Gutter) */
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen),
.chat-popup.chat-popup-maximizing.ai-mode:not(.chat-popup-mobile-fullscreen),
.chat-popup.chat-popup-header-dbl-fullscreen.ai-mode:not(.chat-popup-mobile-fullscreen),
.chat-popup.kinma-chat-popup--wall-snapped.ai-mode:not(.chat-popup-mobile-fullscreen) {
    --kinma-chat-nav-island-bg: #4f46e5;
}

/* Aktive Chatbox: Gutter-Farbe sofort mit KI-/Familien-Modus (hinter .left-nav-cluster) */
body:has(.chat-popup.active.ai-mode:not(.chat-popup-mobile-fullscreen)) {
    --kinma-chat-fs-gutter-bg: #4f46e5;
}

body:has(.chat-popup.active:not(.ai-mode):not(.chat-popup-mobile-fullscreen)) {
    --kinma-chat-fs-gutter-bg: #1a1a1a;
}

body.kinma-chat-ui-mode-switching::before,
body.kinma-chat-ui-mode-switching.kinma-chat-fs-gutter-active::before,
body.kinma-chat-ui-mode-switching.kinma-chat-fs-gutter-pending::before,
body.kinma-chat-ui-mode-switching.kinma-chat-wall-snap-gutter-active::before {
    transition: none !important;
}

/*
 * Linker Streifen hinter der Nav-Insel: Fade beim Maximieren (nicht hart einblenden).
 * Liegt unter Chatbox (100004 aktiv) und unter .left-nav-cluster (100011 wenn Chat aktiv).
 */
body::before {
    content: '';
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: 0;
    background: var(--kinma-chat-fs-gutter-bg, #1a1a1a);
    z-index: 1990;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.28s cubic-bezier(0.32, 0.72, 0, 1);
}

/* Breite während Maximieren-Animation, Opacity erst wenn Chatbox angekommen ist */
body.kinma-chat-fs-gutter-pending::before,
body.kinma-chat-fs-gutter-active::before {
    width: var(--kinma-chat-fs-gutter-width, var(--kinma-chat-fs-left, calc(24px + 3.75em + 24px))) !important;
    background: var(--kinma-chat-fs-gutter-bg, #1a1a1a) !important;
}

body.kinma-chat-fs-gutter-pending::before {
    opacity: var(--kinma-chat-fs-gutter-opacity, 0);
    transition: none;
}

body.kinma-chat-fs-gutter-active::before {
    opacity: 1;
    pointer-events: auto;
    transition: opacity 0.12s ease-out;
}

body.kinma-chat-fs-gutter-active.kinma-chat-fs-gutter-instant::before {
    transition: none;
}

/*
 * Linker Streifen hinter der Nav-Insel bei Seiten-Snap (links / linke Ecken).
 * Volle Höhe bei „left“, obere Hälfte bei top-left, untere bei bottom-left / bottom.
 */
body.kinma-chat-wall-snap-gutter-active::before {
    width: var(--kinma-chat-fs-gutter-width, var(--kinma-chat-fs-left, calc(24px + 3.75em + 24px))) !important;
    background: var(--kinma-chat-fs-gutter-bg, #1a1a1a) !important;
    top: var(--kinma-chat-wall-gutter-top, 0) !important;
    bottom: auto !important;
    height: var(--kinma-chat-wall-gutter-height, 100vh) !important;
    opacity: 1 !important;
    pointer-events: auto;
    /* Kein top/height-Transition — sonst „fällt“ die untere Hälfte beim bottom-left-Snap */
    transition: opacity 0.12s ease-out, background 0.2s ease;
}

body.kinma-chat-wall-snap-gutter-instant::before,
body.kinma-chat-wall-snap-gutter-active.kinma-chat-wall-snap-gutter-instant::before {
    transition: none !important;
}

/* Maximieren: Vollhöhe-Gutter schlägt partielle Wand-Snap top/height (falls Klasse kurz parallel aktiv) */
body.kinma-chat-fs-gutter-pending::before,
body.kinma-chat-fs-gutter-active::before,
body.kinma-chat-fs-gutter-pending.kinma-chat-wall-snap-gutter-active::before,
body.kinma-chat-fs-gutter-active.kinma-chat-wall-snap-gutter-active::before {
    top: 0 !important;
    bottom: 0 !important;
    height: auto !important;
}

/*
 * Nav-Leiste + Body: linke Ecken während Maximieren-Animation und im Vollbild (gleichzeitig zur FLIP-Animation).
 */
.chat-popup.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen) .chat-navigation-section,
.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) .chat-navigation-section,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='left']
    .chat-navigation-section,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='top-left']
    .chat-navigation-section,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom-left']
    .chat-navigation-section,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom']
    .chat-navigation-section {
    align-self: stretch !important;
    min-height: 100% !important;
    height: 100% !important;
    overflow: visible;
}

/* Nur die weiße Front-Leiste rund; Back (#1a1a1a) bleibt eckig → sichtbar in den Kurven */
.chat-popup.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-back,
.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='left']
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='top-left']
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom-left']
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom']
    .chat-nav-rail-back {
    border-radius: 0 !important;
    transition: none !important;
}

.chat-popup.chat-popup-maximizing:not(.chat-popup-mobile-fullscreen):not(.chat-popup--header-tabs-vertical)
    .chat-nav-rail-front,
.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen):not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen):not(
        .chat-popup--header-tabs-vertical
    )[data-kinma-wall-snap-zone='left']
    .chat-nav-rail-front {
    border-top-left-radius: var(--kinma-chat-inner-nav-radius, 24px);
    border-bottom-left-radius: var(--kinma-chat-inner-nav-radius, 24px);
}

/* top-left: äußere Ecke oben links — Back eckig, Front rund; innere Ecke unten links — beide rund */
.chat-popup.chat-popup-maximizing.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='top-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='top-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-back {
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-bottom-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
    transition: none !important;
}

.chat-popup.chat-popup-maximizing.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='top-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='top-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front {
    border-top-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
    border-bottom-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
}

/* bottom-left / bottom: innere Ecke oben links rund; äußere Ecke unten links — Back eckig, Front rund */
.chat-popup.chat-popup-maximizing.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-back,
.chat-popup.chat-popup-maximizing.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-back {
    border-top-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    transition: none !important;
}

.chat-popup.chat-popup-maximizing.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front,
.chat-popup.chat-popup-maximizing.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom-left']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)[data-kinma-wall-snap-zone='bottom']:not(
        .chat-popup--header-tabs-vertical
    )
    .chat-nav-rail-front {
    border-top-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
    border-bottom-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
}

/* Vertikale Tabs: Tab-Leiste + Nav — linke Ecken eckig (Tabs liegen außen links) */
.chat-popup.chat-popup-maximizing.chat-popup--header-tabs-vertical:not(.chat-popup-mobile-fullscreen)
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active,
.chat-popup.chat-popup-header-dbl-fullscreen.chat-popup--header-tabs-vertical:not(.chat-popup-mobile-fullscreen)
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active,
.chat-popup.kinma-chat-popup--wall-snapped.chat-popup--header-tabs-vertical:not(.chat-popup-mobile-fullscreen)
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active {
    align-self: stretch !important;
    min-height: 100% !important;
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    overflow: hidden !important;
}

.chat-popup.chat-popup--header-tabs-vertical:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-front {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
}

.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen):not(
        .chat-popup--header-tabs-vertical
    )[data-kinma-wall-snap-zone='top-left']
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active {
    border-top-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
    border-bottom-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
}

.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen):not(
        .chat-popup--header-tabs-vertical
    )[data-kinma-wall-snap-zone='bottom-left']
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen):not(
        .chat-popup--header-tabs-vertical
    )[data-kinma-wall-snap-zone='bottom']
    .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active {
    border-top-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
    border-bottom-left-radius: var(--kinma-chat-inner-nav-radius, 24px) !important;
}

/* Aero-Snap-Vorschau (gleiche Optik wie Maximieren / Gutter #1a1a1a) */
.kinma-chat-snap-preview {
    position: fixed;
    z-index: 1999;
    pointer-events: none;
    display: none;
    box-sizing: border-box;
    border: 2px solid rgba(26, 26, 26, 0.35);
    background: rgba(26, 26, 26, 0.14);
    border-radius: 12px;
    transition: left 0.08s ease, top 0.08s ease, width 0.08s ease, height 0.08s ease;
}

.kinma-chat-snap-preview[data-zone='top'] {
    border-radius: 0;
}

/*
 * Höhere Spezifität: .chat-popup--user-layout setzt width/max-width oft mit !important (auch in style.css).
 * Ohne diese Zeile bleibt z. B. 1000px Breite + linker Offset → rechte Kante abgeschnitten.
 */
.chat-popup.chat-popup-header-dbl-fullscreen.chat-popup--user-layout:not(.chat-popup-mobile-fullscreen),
.chat-popup.chat-popup-header-dbl-fullscreen.chat-popup--user-layout.has-profile-open:not(.chat-popup-mobile-fullscreen) {
    width: auto !important;
    height: auto !important;
    max-width: calc(100vw - var(--kinma-chat-fs-left) - var(--kinma-chat-fs-right)) !important;
    max-height: calc(100vh - var(--kinma-chat-fs-top) - var(--kinma-chat-fs-bottom)) !important;
    min-width: 0 !important;
    min-height: 0 !important;
}

/* KI ↔ Familie: Akzentfarben sofort (Header, Nav-rail-back, Gutter), keine Verzögerung */
.chat-popup.kinma-mode-switching .chat-popup-header,
.chat-popup.kinma-mode-switching .chat-popup-header-drag-handle,
.chat-popup.kinma-mode-switching .chat-navigation-section,
.chat-popup.kinma-mode-switching .chat-nav-rail-back,
.chat-popup.kinma-mode-switching .chat-popup-window-tab,
.chat-popup.kinma-mode-switching .chat-popup-window-tab-label,
.chat-popup.kinma-mode-switching .chat-popup-window-tab-close,
.chat-popup.kinma-mode-switching .chat-nav-btn {
    transition: none !important;
}

.chat-stories-wrapper {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
    max-width: 40%;
    overflow: visible;
    outline: 2px solid rgb(255, 255, 255);
    background: #1a1a1a;
    border-radius: 24px;
    padding: 0 0 0 10px;
    margin: 0 auto;
    min-height: 40px;
    height: auto;
    order: 2;
    justify-content: flex-start;
}

.chat-stories-wrapper:has(.chat-stories-empty) {
    flex: 0 0 auto;
    max-width: none;
    min-height: 0;
}

.chat-stories-label {
    font-size: 14px;
    font-weight: 500;
    color: #ffffff;
    white-space: nowrap;
    flex-shrink: 0;
    padding: 0 4px;
}

.chat-stories-header {
    display: flex;
    align-items: center;
    gap: 6px;
    flex: 1;
    overflow: visible;
    background: #ffffff;
    border-radius: 50px;
    padding: 6px;
    min-height: 40px;
    height: auto;
    justify-content: center;
}

.chat-stories-header:has(.chat-stories-empty) {
    flex: 0 0 auto;
    padding: 4px 6px;
    min-height: 0;
}

.chat-stories-scroll-header {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    padding: 0;
    min-width: 0;
    height: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    contain: layout;
}

.chat-stories-scroll-header:has(.chat-stories-empty) {
    flex: 0 0 auto;
}

.chat-stories-scroll-header::-webkit-scrollbar {
    height: 4px;
}

.chat-stories-scroll-header::-webkit-scrollbar-track {
    background: transparent;
}

.chat-stories-scroll-header::-webkit-scrollbar-thumb {
    background: rgba(0, 0, 0, 0.2);
    border-radius: 2px;
}

.chat-stories-scroll-header::-webkit-scrollbar-thumb:hover {
    background: rgba(0, 0, 0, 0.3);
}

.chat-stories-add-btn-header {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    color: #6c757d;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.chat-stories-add-btn-header:hover {
    background: #e9ecef;
    border-color: #adb5bd;
    color: #1a1a1a;
}

.chat-stories-add-btn-header svg {
    width: 18px;
    height: 18px;
}

.chat-stories-header .chat-story-item {
    position: relative;
    width: 32px;
    height: 32px;
    flex-shrink: 0;
}

.chat-stories-header .chat-story-avatar {
    position: relative;
    width: 32px;
    height: 32px;
}

.chat-stories-header .chat-story-initials {
    position: relative;
    z-index: 2;
    width: 32px;
    height: 32px;
    font-size: 13px;
    box-shadow: 0 0 0 2px #1a1a1a;
}

.chat-stories-header .chat-story-segments {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 1;
}

.chat-stories-header .chat-story-segments-svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 32px;
    height: 32px;
    display: block;
    overflow: visible;
    shape-rendering: geometricPrecision;
}

.chat-stories-header .chat-story-segments-svg path,
.chat-stories-header .chat-story-segments-svg circle {
    shape-rendering: geometricPrecision;
    paint-order: stroke fill markers;
}

/* Linker Griff zum Verschieben des Popups (Desktop) */
.chat-popup-header-drag-handle {
    order: 0;
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: stretch;
    min-width: var(--kinma-chat-nav-rail-width);
    max-width: var(--kinma-chat-nav-rail-width);
    width: var(--kinma-chat-nav-rail-width);
    padding: 0;
    box-sizing: border-box;
    cursor: grab;
    touch-action: manipulation;
    color: rgba(255, 255, 255, 0.42);
    opacity: 1;
    overflow: hidden;
    transition:
        max-width 0.28s cubic-bezier(0.32, 0.72, 0, 1),
        min-width 0.28s cubic-bezier(0.32, 0.72, 0, 1),
        width 0.28s cubic-bezier(0.32, 0.72, 0, 1),
        opacity 0.22s ease,
        padding 0.28s cubic-bezier(0.32, 0.72, 0, 1),
        color 0.15s ease,
        background 0.15s ease;
    user-select: none;
    -webkit-user-select: none;
}

.chat-popup.chat-popup--resizing .chat-popup-header-drag-handle,
.chat-popup.kinma-chat-popup-flip-anim .chat-popup-header-drag-handle {
    transition: none;
}

.chat-popup-header-drag-handle:hover {
    color: rgba(255, 255, 255, 0.72);
}

.chat-popup-header-drag-handle-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

.chat-popup-header-drag-handle-icon svg {
    flex-shrink: 0;
}

/* Drag-Griff: 6 Punkte als 3×2 (horizontal + vertikal gleich) */
.chat-popup-header-drag-handle-icon > .chat-popup-header-drag-grip--grid-3x2 {
    display: block;
}

/* Vertikal: Griff über Tab-Leiste (Breite = Rail) */
.chat-popup.chat-popup--header-tabs-vertical:not(.chat-popup--header-tabs-disabled) .chat-popup-header-drag-handle {
    width: var(--kinma-chat-vertical-tabs-extra-w, 128px);
    min-width: var(--kinma-chat-vertical-tabs-extra-w, 128px);
    max-width: min(200px, 28vw);
    justify-content: center;
    align-items: center;
}

/* Mehrere Chat-Fenster: Tab-Zeile nutzt gesamte Breite zwischen Griff und Controls (ziehbar über Wrap/Clip) */
.chat-popup-header-tabs-wrap {
    order: 1;
    flex: 1 1 0;
    min-width: 0;
    width: 100%;
    max-width: none;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: stretch;
    justify-content: flex-start;
    gap: 4px;
    margin: 0 4px 0 0;
    min-height: 0;
    cursor: grab;
    --kinma-chat-tab-row-height: 36px;
    transition: margin 0.28s cubic-bezier(0.32, 0.72, 0, 1);
}

.chat-popup-header-drag-spacer {
    order: 2;
    flex: 0 0 0;
    width: 0;
    min-width: 0;
    min-height: 48px;
    align-self: stretch;
    overflow: hidden;
    pointer-events: none;
    cursor: grab;
}

.chat-popup-header-tabs-scroll-clip {
    position: relative;
    flex: 1 1 0;
    min-width: 0;
    display: flex;
    align-items: stretch;
    overflow: hidden;
    --kinma-chat-header-tab-fade: inherit;
    cursor: grab;
}

.chat-popup-header-tabs-scroll-clip::before,
.chat-popup-header-tabs-scroll-clip::after {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    /* Breitere Zone + weichere Stufen: kein sichtbarer „Knick“ am Ende der Rampe */
    width: min(72px, 26%);
    max-width: 104px;
    z-index: 3;
    pointer-events: none;
    opacity: 0;
    transition: opacity 0.35s ease;
}

.chat-popup-header-tabs-scroll-clip::before {
    left: 0;
    background: linear-gradient(
        to right,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 96%, transparent) 0%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 72%, transparent) 18%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 42%, transparent) 38%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 20%, transparent) 58%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 8%, transparent) 76%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 2%, transparent) 91%,
        transparent 100%
    );
}

.chat-popup-header-tabs-scroll-clip::after {
    right: 0;
    background: linear-gradient(
        to left,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 96%, transparent) 0%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 72%, transparent) 18%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 42%, transparent) 38%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 20%, transparent) 58%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 8%, transparent) 76%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 2%, transparent) 91%,
        transparent 100%
    );
}

.chat-popup-header-tabs-scroll-clip.kinma-tabs-fade-left::before {
    opacity: 1;
}

.chat-popup-header-tabs-scroll-clip.kinma-tabs-fade-right::after {
    opacity: 1;
}

.chat-popup-header-tabs-scroll {
    flex: 1 1 auto;
    min-width: 0;
    width: 100%;
    max-width: none;
    overflow-x: auto;
    overflow-y: hidden;
    scrollbar-width: none !important;
    -ms-overflow-style: none;
    display: flex;
    align-items: flex-end;
    cursor: grab;
    /* Tabs immer bündig unten am Header-Rand halten (kein Handle/Strip-Offset). */
    padding-bottom: 0;
    margin-bottom: 0;
    box-sizing: border-box;
}

.chat-popup-header-tabs-scroll::-webkit-scrollbar {
    display: none !important;
    height: 0 !important;
    width: 0 !important;
    background: transparent !important;
}

.chat-popup-header-tabs-scroll::-webkit-scrollbar-thumb,
.chat-popup-header-tabs-scroll::-webkit-scrollbar-track,
.chat-popup-header-tabs-scroll::-webkit-scrollbar-corner {
    background: transparent !important;
    border: 0 !important;
}

.chat-popup-header-tabs-scroll.is-dragging {
    cursor: grabbing;
    user-select: none;
}

.chat-popup-header-tabs-add-slot {
    display: flex;
    align-items: flex-end;
    flex: 0 0 auto;
    align-self: stretch;
}

.chat-popup-header-tabs-inner {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 4px;
    flex-wrap: nowrap;
    flex: 1 1 auto;
    width: 100%;
    min-height: 0;
    padding: 0;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='shared'] {
    flex: 1 1 auto;
    width: 100%;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll'] {
    flex: 0 0 auto;
    width: max-content;
    min-width: min(100%, max-content);
}

.chat-popup-window-tab {
    --kinma-chat-tab-close-size: 22px;
    --kinma-chat-tab-min-width: 32px;
    container-type: inline-size;
    container-name: kinma-chat-tab;
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: stretch;
    gap: 0;
    flex: 1 1 0;
    min-width: var(--kinma-chat-tab-min-width, 32px);
    max-width: var(--kinma-chat-tab-max-width, 147px);
    height: var(--kinma-chat-tab-row-height, 36px);
    min-height: var(--kinma-chat-tab-row-height, 36px);
    max-height: var(--kinma-chat-tab-row-height, 36px);
    padding: 4px 6px 4px 8px;
    box-sizing: border-box;
    border: none;
    border-radius: 10px 10px 0 0;
    background: #1a1a1a;
    color: #e8e8e8;
    font-size: 12px;
    font-weight: 500;
    cursor: pointer;
    align-self: stretch;
    overflow: hidden;
    transition: background 0.15s ease, color 0.15s ease;
    touch-action: none;
}

.chat-popup-window-tab-inner {
    position: relative;
    display: flex;
    align-items: center;
    flex: 1 1 auto;
    min-width: 0;
    max-width: 100%;
    width: 100%;
    gap: 4px;
    justify-content: flex-start;
    box-sizing: border-box;
    padding-right: 0;
    transition:
        justify-content 0.22s cubic-bezier(0.4, 0, 0.2, 1),
        gap 0.22s cubic-bezier(0.4, 0, 0.2, 1),
        padding-right 0.16s ease;
}

.chat-popup-window-tab-leading {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    line-height: 0;
    overflow: hidden;
    opacity: 1;
    transition: opacity 0.16s ease;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='shared'] .chat-popup-window-tab {
    flex: 1 1 0;
    min-width: var(--kinma-chat-tab-min-width, 32px);
    max-width: var(--kinma-chat-tab-max-width, 147px);
    justify-content: flex-start;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll'] .chat-popup-window-tab,
.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll-compact'] .chat-popup-window-tab,
.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll-icon'] .chat-popup-window-tab {
    flex: 0 0 var(--kinma-chat-tab-slot-width, var(--kinma-chat-tab-min-width, 32px));
    width: var(--kinma-chat-tab-slot-width, var(--kinma-chat-tab-min-width, 32px));
    min-width: var(--kinma-chat-tab-min-width, 32px);
    max-width: var(--kinma-chat-tab-slot-width, var(--kinma-chat-tab-min-width, 32px));
    justify-content: flex-start;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll'] .chat-popup-window-tab-label {
    flex: 1 1 auto;
    justify-content: flex-start;
    text-align: left;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll-compact'] .chat-popup-window-tab {
    gap: 3px;
    padding-left: 5px;
    padding-right: 4px;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll-compact'] .chat-popup-window-tab-label {
    flex: 1 1 auto;
    justify-content: flex-start;
    text-align: left;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='scroll-icon'] .chat-popup-window-tab,
.chat-popup-header-tabs-inner[data-kinma-tab-layout='tight'] .chat-popup-window-tab {
    padding-left: 6px;
    padding-right: 6px;
}

.chat-popup-window-tab-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 14px;
    height: 14px;
    line-height: 0;
}

.chat-popup-window-tab-icon svg {
    display: block;
    width: 14px;
    height: 14px;
}

.chat-popup-window-tab-icon--ai svg {
    overflow: visible;
}

.chat-popup-window-tab.is-active .chat-popup-window-tab-icon:not(.chat-popup-window-tab-icon--ai) {
    color: #1a1a1a;
}

.chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active) .chat-popup-window-tab-icon--ai {
    opacity: 1;
}

/* Familien-Tab mit offenem Kontakt: Profilbild statt Sprechblasen-Icon (Tab-Text bleibt), nie bei KI-Tabs */
.chat-popup-window-tab-avatar {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 18px;
    width: 18px;
    height: 18px;
    min-width: 18px;
    min-height: 18px;
    border-radius: 50%;
    overflow: hidden;
    box-sizing: border-box;
    position: relative;
    line-height: 0;
}

.chat-popup-window-tab-avatar-img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
}

.chat-popup-window-tab-avatar-initials {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: calc(18px * 0.34);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
    color: #fff;
    user-select: none;
    pointer-events: none;
}

.chat-popup-window-tab-avatar-initials--duo {
    font-size: calc(18px * 0.28);
    letter-spacing: -0.04em;
}

.chat-popup-window-tab-avatar-initials .chat-group-avatar-icon {
    width: 10px;
    height: 10px;
}

.chat-popup-window-tab-avatar--has-img .chat-popup-window-tab-avatar-initials {
    display: none;
}

/* Vertikale Tabs: Leiste links vor der Chat-Nav (.chat-navigation-section) */
.chat-popup-body-tabs-rail {
    display: none;
    flex: 0 0 auto;
    flex-direction: column;
    align-items: stretch;
    align-self: stretch;
    min-height: 0;
    min-width: 0;
    background: var(--kinma-chat-header-tab-fade, #1a1a1a);
    border-right: 1px solid rgba(255, 255, 255, 0.08);
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
    --kinma-chat-header-tab-fade: #1a1a1a;
    --kinma-chat-vertical-tabs-inset: 8px;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail.chat-popup-body-tabs-rail--active {
    display: flex;
    flex-direction: column;
    position: relative;
    z-index: 10062;
    align-self: stretch;
    min-height: 0;
    height: auto;
    box-sizing: border-box;
}

.chat-popup.ai-mode .chat-popup-body-tabs-rail {
    --kinma-chat-header-tab-fade: #4f46e5;
    background: #4f46e5;
    border-right-color: rgba(255, 255, 255, 0.12);
}

/*
 * Inaktive KI-Tabs: immer KI-Lila (#4f46e5), unabhängig vom globalen Popup-Modus.
 * Familien-Tabs nutzen #1a1a1a; aktiv (.is-active) bleibt weiß.
 */
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active),
.chat-popup-header-tabs-wrap
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active) {
    background: #4f46e5;
    color: #e0e7ff;
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active):hover,
.chat-popup-header-tabs-wrap
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active):hover {
    background: color-mix(in srgb, #4f46e5 88%, #ffffff);
    color: #ffffff;
}

.chat-popup.ai-mode.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active),
.chat-popup.ai-mode .chat-popup-header-tabs-wrap
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active) {
    color: #e0e7ff;
}

.chat-popup.ai-mode.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active):hover,
.chat-popup.ai-mode .chat-popup-header-tabs-wrap
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active):hover {
    color: #ffffff;
}

/* KI-Modus: keine Verlaufs-Fades an der vertikalen Tab-Leiste */
.chat-popup.ai-mode.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-header-tabs-scroll-clip::before,
.chat-popup.ai-mode.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-header-tabs-scroll-clip::after {
    display: none;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-wrap {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    align-items: stretch;
    align-self: stretch;
    width: 100%;
    min-width: 128px;
    max-width: min(200px, 28vw);
    max-height: none;
    height: auto;
    min-height: 0;
    margin: 0;
    padding: 0 var(--kinma-chat-vertical-tabs-inset, 8px) var(--kinma-chat-vertical-tabs-inset, 8px)
        var(--kinma-chat-vertical-tabs-inset, 8px);
    box-sizing: border-box;
    cursor: grab;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-scroll-clip {
    flex: 1 1 auto;
    min-height: 0;
    max-height: none;
    height: auto;
    overflow-x: hidden;
    overflow-y: auto;
    cursor: grab;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-scroll {
    overflow-x: hidden;
    overflow-y: auto;
    align-items: stretch;
    flex: 1 1 auto;
    min-height: 0;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-inner {
    flex-direction: column;
    width: 100%;
    align-items: stretch;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-window-tab {
    flex: 0 0 auto;
    width: 100%;
    min-width: 0;
    max-width: none;
    border-radius: 9999px;
}

/* Vertikal: × bei Hover (Tabs sind volle Breite — Close darf nicht an --shows-label hängen) */
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab:has([data-kinma-tab-close]):hover
    .chat-popup-window-tab-inner,
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-inner {
    padding-right: calc(var(--kinma-chat-tab-close-size, 22px) + 4px);
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab:has([data-kinma-tab-close]):hover
    .chat-popup-window-tab-close,
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-close {
    max-width: var(--kinma-chat-tab-close-size, 22px);
    min-width: var(--kinma-chat-tab-close-size, 22px);
    opacity: 0.88;
    visibility: visible;
    pointer-events: auto;
    cursor: pointer;
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab.is-active:has([data-kinma-tab-close]):hover
    .chat-popup-window-tab-close {
    opacity: 0.72;
}

/* Vertikal + nur Icon (selten): × ersetzt Icon wie in der Header-Zeile */
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab--icon-only.is-active:hover
    .chat-popup-window-tab-inner,
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab--icon-only.is-active:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-inner {
    padding-right: 0 !important;
    justify-content: center;
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab--icon-only.is-active:hover
    .chat-popup-window-tab-leading,
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab--icon-only.is-active:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-leading {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab--icon-only.is-active:hover
    .chat-popup-window-tab-close,
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab--icon-only.is-active:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-close {
    left: 50%;
    right: auto;
    transform: translate(-50%, -50%);
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab.is-active
    .chat-popup-window-tab-close {
    color: #1a1a1a;
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active)
    .chat-popup-window-tab-close {
    color: #eef2ff;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-add-slot {
    align-self: stretch;
    flex-shrink: 0;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-window-tab-add {
    width: 100%;
    min-height: var(--kinma-chat-tab-row-height, 36px);
    border-radius: 9999px;
}

/* Vertikale Scroll-Fades (oben/unten) */
.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-scroll-clip::before,
.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-scroll-clip::after {
    width: 100%;
    max-width: none;
    height: min(56px, 22%);
    max-height: 72px;
    left: 0;
    right: 0;
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-scroll-clip::before {
    top: 0;
    bottom: auto;
    background: linear-gradient(
        to bottom,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 96%, transparent) 0%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 42%, transparent) 55%,
        transparent 100%
    );
}

.chat-popup.chat-popup--header-tabs-vertical .chat-popup-body-tabs-rail .chat-popup-header-tabs-scroll-clip::after {
    top: auto;
    bottom: 0;
    background: linear-gradient(
        to top,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 96%, transparent) 0%,
        color-mix(in srgb, var(--kinma-chat-header-tab-fade, #1a1a1a) 42%, transparent) 55%,
        transparent 100%
    );
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-header-tabs-scroll-clip.kinma-tabs-fade-top::before {
    opacity: 1;
}

.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-header-tabs-scroll-clip.kinma-tabs-fade-bottom::after {
    opacity: 1;
}

/* Legacy-Klasse falls Wrap noch im Header (sollte nicht vorkommen) */
.chat-popup-header-tabs-wrap.chat-popup-header-tabs-wrap--vertical {
    flex-direction: column;
    align-items: stretch;
}

.chat-popup.chat-popup--header-tabs-disabled .chat-popup-header-tabs-wrap {
    display: none !important;
}

.chat-popup.chat-popup--header-tabs-disabled .chat-popup-header-drag-spacer,
.chat-popup.chat-popup--header-tabs-vertical:not(.chat-popup--header-tabs-disabled)
    .chat-popup-header
    > .chat-popup-header-drag-spacer {
    flex: 1 1 auto;
    min-width: 0;
    width: auto;
    pointer-events: auto;
}

.chat-header-context-menu {
    min-width: 200px;
    padding: 6px;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18), 0 0 0 1px rgba(0, 0, 0, 0.06);
}

.chat-header-context-menu .chat-context-menu-item {
    width: 100%;
    border: none;
    background: transparent;
    text-align: left;
    font: inherit;
}

.chat-popup-window-tab:hover {
    background: #1a1a1a;
    color: #fff;
}

.chat-popup-window-tab.is-active {
    background: #ffffff;
    color: #1a1a1a;
}

/*
 * Inaktive Fenster-Tabs: Farbe nach gespeichertem Tab-Modus (data-kinma-window-tab-mode),
 * nicht nach globalem .chat-popup.ai-mode — so bleibt z. B. ein Familien-Tab grau, während ein KI-Tab aktiv ist.
 */
.chat-popup-window-tab[data-kinma-window-tab-mode='chat']:not(.is-active) {
    background: #1a1a1a;
    color: #e8e8e8;
}

.chat-popup-window-tab[data-kinma-window-tab-mode='chat']:not(.is-active):hover,
.chat-popup.chat-popup--header-tabs-vertical
    .chat-popup-body-tabs-rail
    .chat-popup-window-tab[data-kinma-window-tab-mode='chat']:not(.is-active):hover,
.chat-popup-header-tabs-wrap
    .chat-popup-window-tab[data-kinma-window-tab-mode='chat']:not(.is-active):hover {
    background: color-mix(in srgb, #1a1a1a 88%, #ffffff);
    color: #ffffff;
}

.chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active) {
    background: #4f46e5;
    color: #e0e7ff;
}

.chat-popup-window-tab[data-kinma-window-tab-mode='ai']:not(.is-active):hover {
    background: color-mix(in srgb, #4f46e5 88%, #ffffff);
    color: #ffffff;
}

.chat-popup-window-tab-label {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1 1 auto;
    min-width: 0;
    max-width: 12rem;
    opacity: 1;
    text-align: left;
    line-height: 1;
    transition:
        max-width 0.22s cubic-bezier(0.4, 0, 0.2, 1),
        opacity 0.18s ease,
        flex 0.22s cubic-bezier(0.4, 0, 0.2, 1);
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='shared'] .chat-popup-window-tab-label {
    flex: 1 1 auto;
    justify-content: flex-start;
    text-align: left;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='compact'] .chat-popup-window-tab-label {
    flex: 1 1 auto;
    justify-content: flex-start;
    text-align: left;
}

.chat-popup-header-tabs-inner[data-kinma-tab-layout='compact'] .chat-popup-window-tab {
    gap: 3px;
    padding-left: 5px;
    padding-right: 4px;
}

.chat-popup-window-tab-close {
    position: absolute;
    right: 0;
    top: 50%;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--kinma-chat-tab-close-size, 22px);
    height: var(--kinma-chat-tab-close-size, 22px);
    min-width: 0;
    max-width: 0;
    aspect-ratio: 1 / 1;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 6px;
    background: transparent;
    color: inherit;
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    pointer-events: none;
    cursor: default;
    box-sizing: border-box;
    transform: translateY(-50%);
    transition: max-width 0.14s ease, opacity 0.14s ease, background 0.14s ease;
}

.chat-popup-window-tab-close-icon {
    display: block;
    width: 12px;
    height: 12px;
    pointer-events: none;
}

/* × nur bei Tabs mit sichtbarem Label (nicht reine Icon-Tabs) */
.chat-popup-window-tab--shows-label:hover .chat-popup-window-tab-inner,
.chat-popup-window-tab--shows-label:has(.chat-popup-window-tab-close:focus-visible) .chat-popup-window-tab-inner {
    padding-right: calc(var(--kinma-chat-tab-close-size, 22px) + 4px);
}

.chat-popup-window-tab--shows-label:hover .chat-popup-window-tab-close,
.chat-popup-window-tab--shows-label:has(.chat-popup-window-tab-close:focus-visible) .chat-popup-window-tab-close {
    max-width: var(--kinma-chat-tab-close-size, 22px);
    min-width: var(--kinma-chat-tab-close-size, 22px);
    opacity: 0.88;
    visibility: visible;
    pointer-events: auto;
    cursor: pointer;
    transform: translateY(-50%);
}

.chat-popup-window-tab--shows-label.is-active:hover .chat-popup-window-tab-close {
    opacity: 0.72;
}

.chat-popup-window-tab--icon-only:not(.is-active):hover .chat-popup-window-tab-close {
    max-width: 0;
    min-width: 0;
    opacity: 0;
    pointer-events: none;
}

/* Nur-Icon (aktiv): Hover — × zentriert statt Tab-Icon, kein Überlappen */
.chat-popup-window-tab--icon-only.is-active:hover .chat-popup-window-tab-inner,
.chat-popup-window-tab--icon-only.is-active:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-inner {
    padding-right: 0 !important;
    justify-content: center;
}

.chat-popup-window-tab--icon-only.is-active:hover .chat-popup-window-tab-leading,
.chat-popup-window-tab--icon-only.is-active:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-leading {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.chat-popup-window-tab--icon-only.is-active:hover .chat-popup-window-tab-close,
.chat-popup-window-tab--icon-only.is-active:has(.chat-popup-window-tab-close:focus-visible)
    .chat-popup-window-tab-close {
    left: 50%;
    right: auto;
    max-width: var(--kinma-chat-tab-close-size, 22px);
    min-width: var(--kinma-chat-tab-close-size, 22px);
    opacity: 0.88;
    visibility: visible;
    pointer-events: auto;
    cursor: pointer;
    transform: translate(-50%, -50%);
}

.chat-popup-window-tab--icon-only:not(.is-active):hover .chat-popup-window-tab-inner {
    padding-right: 0 !important;
}

.chat-popup-window-tab--icon-only:not(.is-active):hover .chat-popup-window-tab-leading {
    opacity: 1;
}

/* Schmaler Tab: nur Icon, kein × beim Hover (inaktiv) */
@container kinma-chat-tab (max-width: 32px) {
    .chat-popup-window-tab {
        padding-left: 0;
        padding-right: 0;
    }

    .chat-popup-window-tab-inner {
        justify-content: center;
        gap: 0;
        padding-right: 0 !important;
    }

    .chat-popup-window-tab-label {
        flex: 0 0 0;
        max-width: 0;
        opacity: 0;
    }

    .chat-popup-window-tab--icon-only:not(.is-active):hover .chat-popup-window-tab-inner {
        padding-right: 0 !important;
    }

    .chat-popup-window-tab--icon-only:not(.is-active):hover .chat-popup-window-tab-leading {
        opacity: 1;
    }

    .chat-popup-window-tab.is-active:hover .chat-popup-window-tab-leading,
    .chat-popup-window-tab.is-active:has(.chat-popup-window-tab-close:focus-visible)
        .chat-popup-window-tab-leading {
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
    }

    .chat-popup-window-tab.is-active:hover .chat-popup-window-tab-close,
    .chat-popup-window-tab.is-active:has(.chat-popup-window-tab-close:focus-visible)
        .chat-popup-window-tab-close {
        left: 50%;
        right: auto;
        max-width: var(--kinma-chat-tab-close-size, 22px);
        min-width: var(--kinma-chat-tab-close-size, 22px);
        opacity: 0.88;
        visibility: visible;
        pointer-events: auto;
        cursor: pointer;
        transform: translate(-50%, -50%);
    }
}

.chat-popup-window-tab-add {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 0;
    min-width: 40px;
    height: var(--kinma-chat-tab-row-height, 36px);
    min-height: var(--kinma-chat-tab-row-height, 36px);
    max-height: var(--kinma-chat-tab-row-height, 36px);
    padding: 2px 8px 3px;
    box-sizing: border-box;
    flex-shrink: 0;
    align-self: flex-end;
    border: none;
    border-radius: 10px 10px 0 0;
    background: #ffffff;
    color: #1a1a1a;
    font-size: inherit;
    font-weight: inherit;
    line-height: 1;
    cursor: pointer;
    transition: background 0.15s ease;
}

.chat-popup-window-tab-add-plus {
    font-size: 20px;
    font-weight: 300;
    line-height: 1;
}

.chat-popup-window-tab-add-caption {
    font-size: 10px;
    font-weight: 600;
    line-height: 1.1;
    letter-spacing: 0.02em;
}

.chat-popup-window-tab-add:hover {
    background: #ececec;
}

.chat-header-controls {
    display: flex;
    align-items: center;
    gap: 2px;
    flex: 0 0 auto;
    flex-shrink: 0;
    white-space: nowrap;
    order: 10;
    margin-left: auto;
    padding-right: 4px;
    z-index: 2;
}

.chat-header-controls-divider {
    display: none;
    flex-shrink: 0;
    align-self: center;
    width: 1px;
    height: 20px;
    margin: 0;
    background: rgba(255, 255, 255, 0.24);
    border-radius: 1px;
    pointer-events: none;
}

.chat-popup.active:not(.chat-popup-mobile-fullscreen) .chat-header-controls-divider {
    display: block;
}

.chat-popup.ai-mode .chat-header-controls-divider {
    background: rgba(255, 255, 255, 0.38);
}

@media (max-width: 1024px) {
    .chat-header-controls-divider {
        display: none !important;
    }
}

.chat-popup-maximize-btn {
    background: transparent;
    border: none;
    color: #ffffff;
    cursor: pointer;
    padding: 0;
    margin: 8px 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background 0.2s ease, color 0.2s ease;
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
    flex-shrink: 0;
    box-sizing: border-box;
}

.chat-popup-maximize-btn:hover {
    background: rgba(255, 255, 255, 0.15);
    color: #ffffff;
}

.chat-popup-maximize-btn-icon {
    display: block;
    width: 20px;
    height: 20px;
}

.chat-popup-maximize-btn-icon--restore {
    display: none;
}

.chat-popup-maximize-btn--restored .chat-popup-maximize-btn-icon--expand {
    display: none;
}

.chat-popup-maximize-btn--restored .chat-popup-maximize-btn-icon--restore {
    display: block;
}

@media (max-width: 1024px) {
    .chat-popup-maximize-btn {
        display: none !important;
    }
}

.chat-popup.ai-mode .chat-popup-header {
    background: #4f46e5;
    --kinma-chat-header-tab-fade: #4f46e5;
}

/* Standard: Header nur Schatten animieren, Hintergrund bei Moduswechsel sofort */
.chat-popup.active:not(.chat-popup-mobile-fullscreen):not(.kinma-mode-switching) .chat-popup-header {
    transition-property: box-shadow;
    transition-duration: 0.32s;
    transition-timing-function: cubic-bezier(0.32, 0.72, 0, 1);
}

.chat-popup.active:not(.chat-popup-mobile-fullscreen).kinma-mode-switching .chat-popup-header {
    transition: none !important;
}

/* KI-Modus: keine Verlaufs-Fades in der Header-Tab-Zeile */
.chat-popup.ai-mode .chat-popup-header-tabs-scroll-clip::before,
.chat-popup.ai-mode .chat-popup-header-tabs-scroll-clip::after {
    display: none;
}

.chat-popup.ai-mode .chat-popup-header-drag-handle {
    color: rgba(255, 255, 255, 0.5);
}

.chat-popup.ai-mode .chat-popup-header-drag-handle:hover {
    color: rgba(255, 255, 255, 0.85);
}

/* Compact float card: tab strip only, no chatPopup inside */
.kinma-chat-float-window {
    position: fixed;
    z-index: 100002;
    display: flex;
    flex-direction: column;
    width: auto;
    min-width: 0;
    max-width: min(400px, 90vw);
    height: auto;
    max-height: none;
    background: #1a1a1a;
    border-radius: 12px;
    box-shadow: 0 8px 28px rgba(0, 0, 0, 0.45);
    padding: 0;
    cursor: default;
    user-select: none;
    overflow: hidden;
}

.kinma-chat-float-window:not(.kinma-float-active) .kinma-chat-float-popup-host {
    display: none;
}

/* Active float: hosting chatPopup, acts as transparent wrapper */
.kinma-chat-float-window.kinma-float-active {
    width: min(1000px, 94vw);
    min-width: min(360px, 94vw);
    max-width: min(1000px, 94vw);
    height: min(640px, calc(100vh - 40px));
    max-height: min(88vh, calc(100vh - 40px));
    background: transparent;
    box-shadow: none;
    border-radius: 0;
    overflow: visible;
}

.kinma-chat-float-window.kinma-float-active .kinma-chat-float-window-tabs {
    display: none;
}

.kinma-chat-float-window--embed {
    width: min(1000px, calc(100vw - 32px));
    min-width: 340px;
    max-width: min(1000px, calc(100vw - 32px));
    height: min(600px, calc(100vh - 32px));
    max-height: min(600px, calc(100vh - 32px));
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    overflow: visible;
}

.kinma-chat-embed-host {
    position: relative;
    flex: 1 1 auto;
    width: 100%;
    height: 100%;
    min-width: 0;
    min-height: 0;
}

.kinma-chat-embed-frame {
    display: block;
    width: 100%;
    height: 100%;
    border: 0;
    background: transparent;
}

.kinma-chat-embed-drag-overlay {
    position: fixed;
    inset: 0;
    z-index: 100006;
    cursor: move;
    background: transparent;
}

.kinma-chat-float-popup-host {
    flex: 1 1 auto;
    min-height: 0;
    min-width: 0;
    position: relative;
    overflow: hidden;
    border-radius: 0;
    background: transparent;
}

.chat-popup.kinma-chat-popup--docked-float {
    position: absolute !important;
    inset: 0 !important;
    left: 0 !important;
    top: 0 !important;
    right: auto !important;
    bottom: auto !important;
    width: 100% !important;
    height: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    min-height: 0 !important;
    max-height: none !important;
    border-radius: 16px;
    z-index: 1;
}

.kinma-chat-float-close {
    flex-shrink: 0;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 9999px;
    background: transparent;
    color: rgba(255, 255, 255, 0.75);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    box-sizing: border-box;
}

.kinma-chat-float-close:hover {
    background: rgba(255, 255, 255, 0.1);
    color: #fff;
}

.kinma-chat-float-window-tabs {
    display: flex;
    flex-direction: row;
    align-items: stretch;
    gap: 4px;
    padding: 6px 8px;
    max-width: 100%;
    flex-shrink: 0;
    cursor: grab;
    --kinma-chat-header-tab-fade: #1a1a1a;
    --kinma-chat-tab-row-height: 36px;
}

.kinma-chat-float-window-tabs .chat-popup-header-tabs-scroll-clip {
    flex: 1 1 0;
    min-width: 0;
}

.kinma-chat-float-window-tabs .chat-popup-header-tabs-scroll {
    max-width: 100%;
}

.kinma-chat-float-window-tabs .chat-popup-header-tabs-add-slot {
    flex-shrink: 0;
}

.kinma-chat-tab-drag-ghost {
    position: fixed;
    z-index: 100005;
    pointer-events: none;
    padding: 6px 12px;
    background: #1a1a1a;
    color: #fff;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 500;
    max-width: 168px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.4);
}

.kinma-chat-tab-drag-ghost--tab {
    max-width: none;
    overflow: hidden;
    text-overflow: clip;
    white-space: normal;
    box-sizing: border-box;
    border-radius: 10px 10px 0 0 !important;
    box-shadow: none !important;
    opacity: 1;
    cursor: grabbing;
}

.chat-popup-window-tab.kinma-chat-tab-drag-ghost.kinma-chat-tab-drag-ghost--tab {
    position: fixed !important;
    z-index: 100005 !important;
    pointer-events: none !important;
    display: inline-flex !important;
    flex: none !important;
    flex-shrink: 0 !important;
    flex-grow: 0 !important;
    align-self: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    white-space: normal !important;
    text-overflow: clip !important;
    container-type: normal !important;
}

.chat-popup-window-tab.kinma-chat-tab-drag-ghost.kinma-chat-tab-drag-ghost--tab.kinma-chat-tab-drag-ghost--detached {
    box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22) !important;
}

.kinma-chat-tab-drop-hover::after {
    content: '';
    position: absolute;
    inset: 3px;
    border: 2px dashed rgba(99, 102, 241, 0.75);
    border-radius: 12px;
    pointer-events: none;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.12);
}

.kinma-chat-tab-reorder-gap {
    flex: 0 0 auto;
    box-sizing: border-box;
    align-self: stretch;
    border-radius: 10px 10px 0 0;
    background: rgba(99, 102, 241, 0.08);
    border: 2px dashed rgba(99, 102, 241, 0.45);
    pointer-events: none;
    overflow: hidden;
}

.chat-popup-header-tabs-inner.kinma-chat-tabs-reordering {
    min-height: var(--kinma-chat-tab-row-height, 36px);
}

.chat-popup-header-tabs-inner.kinma-chat-tabs-reordering .chat-popup-window-tab:not(.kinma-chat-tab-drag-source) {
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

.chat-popup-header-tabs-inner.kinma-chat-tabs-reordering .chat-popup-window-tab.kinma-chat-tab-drag-source {
    visibility: hidden !important;
    flex: 0 0 0 !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
    pointer-events: none !important;
}

.kinma-chat-tab-drag-ghost--tab .chat-popup-window-tab-close,
.kinma-chat-tab-drag-ghost--tab [data-kinma-tab-close],
.kinma-chat-tab-drag-ghost--tab [data-kinma-clone-tab-close] {
    display: none !important;
}

.kinma-chat-tab-drag-ghost--tab .chat-popup-window-tab-inner {
    padding-right: 0 !important;
}

@media (max-width: 1024px) {
    .kinma-chat-float-window {
        display: none !important;
    }
}

.chat-header-ai-btn {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 8px;
    padding: 6px 12px;
    color: #ffffff;
    cursor: pointer;
    transition: all 0.2s ease;
    font-size: 14px;
    font-weight: 500;
    margin-right: 12px;
}

.chat-header-ai-btn:hover {
    background: rgba(255, 255, 255, 0.2);
    border-color: rgba(255, 255, 255, 0.3);
}

.chat-header-fullscreen-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    border-radius: 0;
    padding: 0 8px;
    color: #ffffff;
    cursor: pointer;
    transition: all 0.2s ease;
    width: 40px;
    min-width: 40px;
    height: 100%;
    min-height: 48px;
    flex-shrink: 0;
}

.chat-header-fullscreen-btn:hover {
    background: rgba(255, 255, 255, 0.1);
}

.chat-header-fullscreen-btn svg {
    width: 18px;
    height: 18px;
}

.chat-header-ai-btn svg {
    width: 18px;
    height: 18px;
}

.chat-popup-close {
    background: transparent;
    border: none;
    color: #ffffff;
    cursor: pointer;
    padding: 0;
    margin: 8px 8px 8px 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background 0.2s ease, color 0.2s ease;
    width: 32px;
    min-width: 32px;
    height: 32px;
    min-height: 32px;
    align-self: center;
    flex-shrink: 0;
    box-sizing: border-box;
}

.chat-popup-close[data-kinma-chat-header-mode="minimize"]:hover {
    background: rgba(255, 255, 255, 0.15);
    color: #ffffff;
}

.chat-popup-close[data-kinma-chat-header-mode="minimize"]:hover svg {
    stroke: #ffffff;
}

.chat-popup-close[data-kinma-chat-header-mode="close"]:hover {
    background: rgba(220, 53, 69, 0.35);
    color: #ffb3b8;
}

.chat-popup-close[data-kinma-chat-header-mode="close"]:hover svg {
    stroke: #ffb3b8;
}

.chat-status-indicator {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    transition: background-color 0.3s ease;
}

.chat-status-indicator[data-status="green"] {
    background-color: #28a745;
}

.chat-status-indicator[data-status="yellow"] {
    background-color: #ffc107;
}

.chat-status-indicator[data-status="red"] {
    background-color: #dc3545;
}

.chat-popup-body {
    display: flex;
    flex-direction: row;
    flex: 1;
    min-width: 0;
    min-height: 0;
    width: 100%;
    overflow: hidden;
    align-items: stretch;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    transition:
        border-top-left-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        border-bottom-left-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1);
}

.chat-popup.kinma-mode-switching .chat-popup-body,
.chat-popup.kinma-chat-popup--resizing .chat-popup-body {
    transition: none !important;
}

.chat-popup-content-wrapper {
    position: relative;
    flex: 1;
    min-width: 0;
    width: 100%;
    display: flex;
    flex-direction: row;
    overflow: hidden;
    contain: layout style;
}

/* Chat sidebar: contain content so story segments never bleed into main area */
.chat-sidebar {
    overflow: hidden;
    contain: layout;
}

.chat-contacts-list {
    contain: layout;
}

/* New contacts view: clear structure and overflow */
.chat-new-contacts-view {
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
    overflow: hidden;
    width: 100%;
}

.chat-new-contacts-list {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    min-height: 0;
}

.chat-stories-sidebar {
    width: 80px;
    min-width: 80px;
    max-width: 80px;
    display: flex;
    flex-direction: column;
    background: #f8f9fa;
    border-right: 1px solid #e9ecef;
    flex-shrink: 0;
    position: relative;
}

.chat-stories-scroll {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 16px 0;
}

.chat-stories-scroll::-webkit-scrollbar {
    width: 4px;
}

.chat-stories-scroll::-webkit-scrollbar-track {
    background: transparent;
}

.chat-stories-scroll::-webkit-scrollbar-thumb {
    background: #dee2e6;
    border-radius: 2px;
}

.chat-stories-scroll::-webkit-scrollbar-thumb:hover {
    background: #adb5bd;
}

.chat-stories-scroll:has(.chat-stories-empty) {
    flex: 0 0 auto;
    padding: 0;
}

.chat-stories-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4px;
    min-height: auto;
    height: auto;
    width: 100%;
}

/* Im Header: kompakte Höhe wie ein Story-Thumbnail (32px) */
.chat-stories-header .chat-stories-empty {
    padding: 0 2px;
}
.chat-stories-header .chat-stories-empty-circle {
    width: 32px;
    height: 32px;
    border-width: 2px;
}
.chat-stories-header .chat-stories-empty-text {
    font-size: 7px;
    padding: 0 2px;
    line-height: 1.15;
}

.chat-stories-empty-circle {
    width: 56px;
    height: 56px;
    border: 3px dashed #dee2e6; /* Gestrichelte Outline */
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: transparent;
    margin: 0 auto;
}

.chat-stories-empty-text {
    font-size: 9px;
    font-weight: 600;
    line-height: 1.2;
    color: #9ca3af;
    text-align: center;
    padding: 4px;
    letter-spacing: -0.3px;
}

.chat-story-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 5px;
    width: auto;
    min-width: 56px;
    flex-shrink: 0;
    border-radius: 0;
    position: relative;
    cursor: default;
    transition: opacity 0.15s ease;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
    padding: 0;
    height: auto;
}
.chat-story-item .chat-stories-pillbar-wrap {
    display: flex;
    align-items: center;
    width: 56px;
    min-width: 56px;
    height: 28px;
    padding: 0 6px;
    border: 1px solid #dee2e6;
    border-radius: 14px;
    background: #f5f6f8;
    box-sizing: border-box;
    flex-shrink: 0;
}
.chat-story-item .chat-stories-pillbar-wrap:focus-within {
    border-color: #adb5bd;
    background: #fff;
}
.chat-story-item .chat-stories-pillbar-wrap .chat-stories-pillbar {
    flex: 1;
    min-width: 0;
    height: 22px;
    padding: 0 2px 0 0;
    border: none;
    background: transparent;
    border-radius: 0;
    font-size: 13px;
}
.chat-story-item .chat-stories-pillbar-wrap .chat-stories-pillbar:focus {
    outline: none;
}

/* Musik-Icon in der Pille – Klick öffnet direkt das Lied-Modal */
.chat-story-item .chat-stories-pillbar-music-btn {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: #868e96;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
}
.chat-story-item .chat-stories-pillbar-music-btn:hover {
    color: #1a1a1a;
}
.chat-story-item .chat-story-avatar {
    width: 56px;
    height: 56px;
    flex-shrink: 0;
    cursor: pointer;
}

.chat-story-item.all-viewed {
    opacity: 0.6;
}

.chat-story-item.all-viewed:hover {
    opacity: 0.8;
}

.chat-story-item.active {
    background: rgba(99, 102, 241, 0.15); /* Bläulicher Hintergrund */
    border-radius: 50%;
    padding: 2px;
}

.chat-story-item.active .chat-story-avatar {
    /* Background wird dynamisch gesetzt, daher kein statischer Hintergrund */
    border-radius: 50%;
}

.chat-story-avatar {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: visible; /* Wichtig für SVG-Segmente */
    border: none; /* Keine durchgehende Outline */
    outline: none; /* Keine Outline */
}

.chat-story-segments {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 56px;
    height: 56px;
    pointer-events: none;
    z-index: 0; /* Unter den Initialen, aber über dem Hintergrund */
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    border: none !important;
    outline: none !important;
    box-shadow: none !important;
}

.chat-story-segments-svg {
    position: absolute;
    top: 0;
    left: 0;
    width: 56px;  /* Exakte Größe */
    height: 56px; /* Exakte Größe */
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
    overflow: visible;
    z-index: 0;
    border: none !important;
    outline: none !important;
    
    /* Anti-Aliasing & Glättung */
    shape-rendering: geometricPrecision;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    
    /* Hardware-Beschleunigung für glatte Darstellung */
    will-change: transform;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transform: translateZ(0);
}

.chat-story-segments-svg path,
.chat-story-segments-svg circle {
    shape-rendering: geometricPrecision;
    paint-order: stroke fill markers;
    stroke-opacity: 1 !important;
    fill-opacity: 1 !important;
}

.chat-story-initials {
    position: relative;
    z-index: 2; /* Über den Segmenten */
    width: 40px; /* Optimiert für größeres SVG und besseren Gap */
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: white;
    font-weight: 600;
    font-size: 17px;
    border: none !important; /* Keine Outline */
    outline: none !important; /* Keine Outline */
    box-shadow: none !important; /* Kein Schatten der als Outline wirkt */
    /* Kein weißer Ring mehr - keine Outline zwischen Segmenten und Circle */
    
    /* Anti-Aliasing für perfekte Kreisform */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.chat-story-item.all-viewed .chat-story-initials {
    background: linear-gradient(135deg, #adb5bd 0%, #868e96 100%);
    opacity: 0.7;
}

.chat-story-item.all-viewed .chat-story-segments-svg path,
.chat-story-item.all-viewed .chat-story-segments-svg circle {
    stroke: #adb5bd;
    opacity: 0.7;
}

.chat-stories-add-btn {
    width: 56px;
    height: 56px;
    border-radius: 50%;
    background: #ffffff;
    color: #6c757d;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 16px;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.chat-stories-add-btn:hover {
    background: #f8f9fa;
    border-color: #adb5bd;
    color: #1a1a1a;
}

.chat-stories-add-btn svg {
    width: 24px;
    height: 24px;
}

.chat-sidebar {
    width: 280px;
    min-width: 280px;
    max-width: 280px;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    position: relative;
    /* Width-Transition verursacht starke Layout-Janks beim Expandieren (Kontakt öffnen). */
    transition: none !important;
    overflow: hidden;
    flex-shrink: 0;
    will-change: auto;
    border-right: 1px solid #e9ecef; /* Add border as split line */
}

.chat-popup:not(.has-active-contact) .chat-sidebar {
    width: 100%;
    min-width: 100%;
    max-width: 100%;
}

/* In default chat view always reserve space for chat area: fixed sidebar width */
.chat-popup.active:not(.view-calls):not(.view-stories):not(.view-archived):not(.view-new-contacts):not(.view-settings):not(.view-notes) .chat-sidebar,
.chat-popup.active:not(.view-calls):not(.view-stories):not(.view-archived):not(.view-new-contacts):not(.view-settings):not(.view-notes) #chatSidebar {
    width: 280px !important;
    min-width: 280px !important;
    max-width: 280px !important;
}

.chat-popup.has-active-contact:not(.view-notes) .chat-sidebar {
    width: 280px !important;
    min-width: 280px !important;
    max-width: 280px !important;
}

.chat-main {
    display: flex;
    flex: 1;
    min-width: 0;
}

/* === View-state visibility system ===
   chatMain and chatSidebar are ALWAYS visible in chat view.
   JS sets view classes on #chatPopup to switch views — no inline display:none on chatMain. */

/* Default (chat view): chatMain and sidebar always visible (exclude view-new-contacts and view-chat so their own rules apply) */
.chat-popup.active:not(.view-calls):not(.view-stories):not(.view-archived):not(.view-new-contacts):not(.view-settings):not(.view-chat) #chatMain,
.chat-popup.active.view-chat.has-active-contact #chatMain,
.chat-popup.active.view-archived.has-active-contact #chatMain,
.chat-popup.active.view-new-contacts.view-new-contacts-selected #chatMain {
    display: flex !important;
}
.chat-popup.active:not(.view-calls):not(.view-stories):not(.view-archived):not(.view-new-contacts):not(.view-settings):not(.view-notes) #chatSidebar {
    display: flex !important;
}
.chat-popup.active:not(.view-calls):not(.view-stories):not(.view-archived):not(.view-new-contacts):not(.view-settings):not(.view-notes) #chatDivider {
    display: flex !important;
}
.chat-popup.active.view-new-contacts.view-new-contacts-selected #chatDivider,
.chat-popup.active.view-archived.has-active-contact #chatDivider {
    display: flex !important;
}

/* Calls view: hide chat area */
.chat-popup.active.view-calls #chatMain,
.chat-popup.active.view-calls #chatSidebar,
.chat-popup.active.view-calls #chatDivider {
    display: none !important;
}

/* Notizen: nur Verlauf, keine Kontaktliste */
.chat-popup.active.view-notes #chatContactsPanel,
.chat-popup.active.view-notes #chatSidebar,
.chat-popup.active.view-notes #chatDivider,
.chat-popup.active.view-notes .chat-contacts-toolbar {
    display: none !important;
}

.chat-popup.active.view-notes #chatViewSplit {
    display: flex !important;
}

.chat-popup.active.view-notes.has-active-contact #chatMain {
    display: flex !important;
    flex: 1 1 auto !important;
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

.chat-popup.active.view-notes.has-active-contact .chat-main {
    flex: 1 1 100% !important;
    max-width: 100% !important;
}

/* Notizen: kein Kontakt-Header (Avatar, Anrufe); Verlauf + Composer bleiben */
.chat-popup.active.view-notes #chatMainHeader,
.chat-popup.active.view-notes #chatMain > .chat-main-header-row > .chat-main-header,
.chat-popup.active.view-notes #chatMain > .chat-main-header {
    display: none !important;
}

.chat-popup.active.view-notes #chatCallButtons,
.chat-popup.active.view-notes .chat-header-call-controls {
    display: none !important;
}

.chat-popup.active.view-notes #chatMainHeaderBackIsland,
.chat-popup.active.view-notes #chatGhostCloseIsland {
    display: none !important;
}

.chat-popup.active.view-notes:not(.has-active-contact) #chatMainHeaderSearchIsland {
    display: none !important;
}

/* Notizen mit offenem Verlauf: nur Such-Pille rechts (kein Kontakt-Header) */
.chat-popup.active.view-notes.has-active-contact #chatMain .chat-main-header-row {
    justify-content: flex-end !important;
}

/* Settings view: hide chat area, settings panel visible via JS/chat-enhancements */
.chat-popup.active.view-settings #chatMain,
.chat-popup.active.view-settings #chatSidebar,
.chat-popup.active.view-settings #chatDivider {
    display: none !important;
}

/* Archiv ohne geöffneten Chat: wie Chat-Liste — kein Verlauf */
.chat-popup.active.view-archived:not(.has-active-contact) #chatMain,
.chat-popup.active.view-archived:not(.has-active-contact) #chatDivider {
    display: none !important;
}

/* Vertikale Tabs ohne Kontakt: nur Kontaktliste, kein leerer Haupt-Chat */
.chat-popup.active.chat-popup--header-tabs-vertical:not(.has-active-contact):not(.view-calls):not(
        .view-stories
    ):not(.view-settings):not(.view-new-contacts) #chatMain,
.chat-popup.active.chat-popup--header-tabs-vertical:not(.has-active-contact):not(.view-calls):not(
        .view-stories
    ):not(.view-settings) #chatDivider {
    display: none !important;
}

/* Archiv: gleiche Kontaktspalte wie Chat (weiß, keine abweichende „Unterseiten“-Optik) */
.chat-popup.active.view-archived #chatContactsPanel {
    background: #fff;
}

/* New contacts view: hide chatMain/divider until a contact is selected */
.chat-popup.active.view-new-contacts:not(.view-new-contacts-selected) #chatMain,
.chat-popup.active.view-new-contacts:not(.view-new-contacts-selected) #chatDivider {
    display: none !important;
}

/* Chat + New-contact sections: right-side area fills to the right like Calls/Stories */
.chat-popup.active:not(.view-calls):not(.view-stories):not(.view-archived):not(.view-new-contacts):not(.view-settings):not(.view-chat) #chatMain,
.chat-popup.active.view-chat.has-active-contact #chatMain,
.chat-popup.active.view-archived.has-active-contact #chatMain,
.chat-popup.active.view-new-contacts.view-new-contacts-selected #chatMain {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    width: 100% !important;
}
.chat-popup.active.view-new-contacts:not(.view-new-contacts-selected) #chatNewContactsView {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* Always show chat content when popup is active and chatMain is visible */
.chat-popup.active:not(.view-notes) #chatMain > .chat-main-header-row > .chat-main-header,
.chat-popup.active:not(.view-notes) #chatMain > .chat-main-header {
    display: flex !important;
}

/* KI-Modus: Header-Zeile mit Titel + Sprachanruf (kein Video) */
.chat-popup.active.ai-mode #chatMain > .chat-main-header-row {
    display: flex !important;
}

.chat-popup.active.ai-mode #chatMain > .chat-main-header-row > #chatMainHeader:not(.chat-main-header-call-active) {
    display: flex !important;
}
.chat-popup.active #chatMain > .chat-messages {
    display: flex !important;
    box-sizing: border-box !important;
}
.chat-popup.active #chatMain > .chat-input-container {
    display: flex !important;
}

/* Exception: when an active in-call overlay is shown inside chatMain */
.chat-popup.active #chatMain > .chat-call-view.active ~ .chat-messages,
.chat-popup.active #chatMain > .chat-call-view.active ~ .chat-input-container {
    display: none !important;
}

/* Video-/Sprachanruf: gesamter Chat-Hauptbereich = Kamera/Anruf, Header-Zeile ausblenden */
.chat-popup.active #chatMain > .chat-call-view.active ~ .chat-main-header-row {
    display: none !important;
}

.chat-popup:has(#chatStoryCreation[style*="display: flex"]) .chat-main,
.chat-popup:has(#chatStoryCreation[style*="display: block"]) .chat-main {
    display: none !important;
}

.chat-sidebar.collapsed {
    width: 0;
    min-width: 0;
}

.chat-sidebar.collapsed > * {
    visibility: hidden;
}

.chat-sidebar {
    width: 280px !important;
    min-width: 280px !important;
    max-width: 280px !important;
}

.chat-popup.has-active-contact:not(.view-notes) .chat-sidebar {
    width: 280px !important;
    min-width: 280px !important;
    max-width: 280px !important;
}

.chat-divider {
    width: 1px;
    background: #e9ecef;
    cursor: default;
    position: relative;
    display: flex; /* Show divider as visual split line */
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
    flex-shrink: 0;
    border-left: none;
    border-right: none;
    pointer-events: none; /* Disable interaction */
}

.chat-divider:hover {
    background: #adb5bd;
}

.chat-divider-handle {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #6c757d;
    opacity: 0; /* Always hidden */
    pointer-events: none;
}

.chat-divider-icon {
    transition: transform 0.25s ease;
    will-change: transform;
}

.chat-sidebar.collapsed ~ .chat-divider {
    width: 24px;
    background: #1a1a1a;
    border-left: 1px solid #1a1a1a;
    border-right: 1px solid #1a1a1a;
}

.chat-sidebar.collapsed ~ .chat-divider:hover {
    background: #1a1a1a;
}

.chat-sidebar.collapsed ~ .chat-divider .chat-divider-handle {
    opacity: 1;
    color: #ffffff;
    pointer-events: auto;
}

.chat-sidebar.collapsed ~ .chat-divider .chat-divider-icon {
    transform: rotate(180deg);
}

.chat-tabs {
    display: flex;
    flex-direction: column;
    background: #ffffff;
    border-bottom: 1px solid #e9ecef;
    padding: 12px 10px;
    gap: 6px;
}

.chat-sidebar.collapsed .chat-tabs {
    display: none;
}

.chat-tabs-row {
    display: flex;
    gap: 6px;
}

.chat-tabs-archived {
    display: none; /* Hidden by default, shown when archived tab exists */
}

/* Section-Tabs wie Nav-Island: gleicher Auswahlstil (runder Hellgrau-Hintergrund, kein Rahmen) */
.chat-tab {
    flex: 1;
    min-width: 0;
    padding: 8px 14px;
    background: transparent;
    border: none;
    border-radius: 9999px;
    font-size: 13px;
    font-weight: 500;
    color: #6c757d;
    cursor: pointer;
    transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    position: relative;
    text-align: center;
    line-height: 1.3;
    box-shadow: none;
}

.chat-tabs-archived .chat-tab {
    padding: 6px 14px;
    font-size: 12px;
    min-height: auto;
    height: auto;
    line-height: 1.4;
}

.chat-tabs-archived .chat-tab svg {
    width: 14px;
    height: 14px;
    margin-right: 4px;
    vertical-align: middle;
}

.chat-tab:hover {
    color: #1a1a1a;
    background: #f8f9fa;
}

.chat-tab.active {
    color: #1a1a1a;
    background: #e9ecef;
    background-color: #e9ecef;
    box-shadow: none;
}

.chat-tab.active:hover {
    background: #dee2e6;
    background-color: #dee2e6;
}

.chat-search-container {
    padding: 10px;
    background: #ffffff;
    border-bottom: 1px solid #e9ecef;
    position: relative;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
}

.chat-sidebar.collapsed .chat-search-container {
    display: none;
}

.chat-search-wrapper {
    position: relative;
    display: flex;
    align-items: center;
    background: #f8f9fa;
    border: 1px solid transparent;
    border-radius: 12px;
    padding: 0;
    transition: all 0.2s ease;
    width: 100%;
    min-width: 0;
    overflow: hidden;
    box-sizing: border-box;
}

.chat-search-wrapper:focus-within {
    background: #ffffff;
    border-color: #e9ecef;
}

.chat-search-back-btn {
    width: 32px;
    height: 32px;
    margin: 2px 4px 2px 2px;
    border-radius: 8px;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    color: #6c757d;
    flex-shrink: 0;
}

.chat-search-back-btn:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-search-back-btn svg {
    width: 18px;
    height: 18px;
}

.chat-search-icon {
    position: absolute;
    left: 10px;
    color: #6c757d;
    pointer-events: none;
    z-index: 1;
    width: 16px;
    height: 16px;
    transition: left 0.2s ease;
}

.chat-search-wrapper.has-back-btn .chat-search-icon {
    left: 46px; /* 32px Button + 4px margin + 10px padding */
}

.chat-search-wrapper.has-back-btn .chat-search-input {
    padding-left: 58px; /* 46px Icon Position + 12px padding */
}

.chat-search-input {
    flex: 1;
    min-width: 0;
    padding: 8px 10px 8px 32px;
    border: none;
    border-radius: 16px;
    font-size: 12px;
    outline: none;
    transition: all 0.2s ease;
    background: transparent;
    color: #1a1a1a;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 100%;
    box-sizing: border-box;
}

.chat-search-input::placeholder {
    color: #6c757d;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-filter-btn {
    width: 28px;
    height: 28px;
    margin: 2px;
    border-radius: 8px;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.2s ease;
    color: #6c757d;
    flex-shrink: 0;
    min-width: 28px;
}

.chat-filter-btn:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-filter-btn.active {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-filter-dropdown {
    position: absolute;
    top: 100%;
    right: 12px;
    margin-top: 4px;
    width: 200px;
    background: #ffffff;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    z-index: 100;
    display: none;
    flex-direction: column;
    max-height: 320px;
    overflow: hidden;
}

.chat-filter-dropdown.active {
    display: flex;
}

.chat-filter-header {
    padding: 10px 12px;
    font-weight: 600;
    font-size: 13px;
    color: #1a1a1a;
    border-bottom: 1px solid #e9ecef;
    flex-shrink: 0;
}

.chat-filter-content {
    flex: 1;
    overflow-y: auto;
    padding: 8px 0;
}

.chat-filter-group {
    padding: 6px 12px;
    border-bottom: 1px solid #f8f9fa;
}

.chat-filter-group:last-of-type {
    border-bottom: none;
}

.chat-filter-group-label {
    font-size: 11px;
    font-weight: 600;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    margin-bottom: 6px;
}

.chat-filter-options-compact {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.chat-filter-option-compact {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 4px 0;
    cursor: pointer;
    font-size: 13px;
    color: #1a1a1a;
    user-select: none;
    transition: color 0.15s ease;
}

.chat-filter-option-compact:hover {
    color: #1a1a1a;
}

.chat-filter-option-compact input[type="checkbox"],
.chat-filter-option-compact input[type="radio"] {
    cursor: pointer;
    width: 14px;
    height: 14px;
    margin: 0;
    flex-shrink: 0;
}

.chat-filter-option-compact span {
    flex: 1;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-filter-actions {
    padding: 8px 12px;
    display: flex;
    justify-content: flex-end;
    border-top: 1px solid #e9ecef;
    flex-shrink: 0;
    background: #f8f9fa;
}

.chat-filter-clear {
    padding: 5px 10px;
    background: transparent;
    border: 1px solid #dee2e6;
    border-radius: 4px;
    font-size: 12px;
    font-weight: 500;
    color: #6c757d;
    cursor: pointer;
    transition: all 0.2s ease;
}

.chat-filter-clear:hover {
    background: #ffffff;
    color: #1a1a1a;
    border-color: #1a1a1a;
}

.chat-filter-content::-webkit-scrollbar {
    width: 4px;
}

.chat-filter-content::-webkit-scrollbar-track {
    background: transparent;
}

.chat-filter-content::-webkit-scrollbar-thumb {
    background: #dee2e6;
    border-radius: 2px;
}

.chat-filter-content::-webkit-scrollbar-thumb:hover {
    background: #ced4da;
}

.chat-contacts-list {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-sidebar.collapsed .chat-contacts-list {
    display: none;
}

.chat-ai-assistant-container {
    padding: 12px;
    border-top: 1px solid #e9ecef;
    background: #ffffff;
    flex-shrink: 0;
}

.chat-sidebar.collapsed .chat-ai-assistant-container {
    display: none;
}

.chat-ai-assistant-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 12px 16px;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    color: #ffffff;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 2px 4px rgba(99, 102, 241, 0.2);
}

.chat-popup.ai-mode .chat-ai-assistant-btn {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.35);
}

.chat-popup.ai-mode .chat-ai-assistant-btn:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.4);
    transform: translateY(-1px);
}

.chat-ai-assistant-btn:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
    box-shadow: 0 4px 8px rgba(99, 102, 241, 0.3);
    transform: translateY(-1px);
}

.chat-navigation-section {
    position: relative;
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    align-self: stretch;
    width: var(--kinma-chat-nav-rail-width, 64px);
    min-height: 0;
    height: auto;
    padding: 0;
    background: transparent;
    border-right: none;
    box-shadow: none;
    overflow: visible;
}

.chat-nav-rail-back {
    position: absolute;
    inset: 0;
    background: var(--kinma-chat-nav-island-bg, #1a1a1a);
    z-index: 0;
    pointer-events: none;
    border-radius: 0;
}

.chat-nav-rail-front {
    position: relative;
    z-index: 1;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    box-sizing: border-box;
    width: 100%;
    min-height: 100%;
    flex: 1;
    padding: 8px;
    background: #ffffff;
    border: none;
    outline: none;
    box-shadow: none;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
    overflow: hidden;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    transition:
        border-top-left-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        border-bottom-left-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1);
}

/* Restore / Unsnap: Ecken sofort flach (nicht nach FLIP-Ende), gleiche Dauer wie FLIP beim Einzoomen */
.chat-popup.kinma-chat-popup-flip-anim:not(.chat-popup-maximizing):not(.chat-popup-header-dbl-fullscreen):not(
        .kinma-chat-popup--wall-snapped
    )
    .chat-nav-rail-front {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    transition: none !important;
}

.chat-popup.kinma-chat-popup-flip-anim.chat-popup-maximizing .chat-nav-rail-front,
.chat-popup.kinma-chat-popup-flip-anim.kinma-chat-popup--wall-snapped .chat-nav-rail-front,
.chat-popup.kinma-chat-popup-flip-anim.chat-popup-header-dbl-fullscreen .chat-nav-rail-front {
    transition:
        border-top-left-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1),
        border-bottom-left-radius 0.32s cubic-bezier(0.32, 0.72, 0, 1) !important;
}

.chat-popup.kinma-mode-switching .chat-nav-rail-back,
.chat-popup.kinma-mode-switching .chat-nav-rail-front {
    transition: none !important;
}

.chat-popup.kinma-mode-switching .chat-nav-rail-back {
    background-color: var(--kinma-chat-nav-island-bg, #1a1a1a);
}

.chat-nav-top {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    justify-content: flex-start;
    width: 100%;
    padding-top: 0;
}

/* Archiv: eigene Nav-Sektion unter Chat/Neue Kontakte/Anrufe */
.chat-nav-archive-section,
.chat-nav-top-archived {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    flex-shrink: 0;
    padding: 10px 0 8px;
    margin-top: 6px;
    border-top: 1px solid #e2e8f0;
    gap: 6px;
}

.chat-nav-archive-section.chat-nav-top-archived--visible,
.chat-nav-top-archived.chat-nav-top-archived--visible {
    display: flex;
}

.chat-popup.ai-mode .chat-nav-archive-section,
.chat-popup.ai-mode .chat-nav-top-archived {
    display: none !important;
}

/* KI-Modus Desktop: linke Leiste mit KI-Chat, Familien-Umschalter (Mitte), Einstellungen unten */
.chat-popup.ai-mode.chat-popup-mobile-fullscreen .chat-navigation-section {
    display: none !important;
}

.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-navigation-section {
    display: flex !important;
}

/* Desktop-Header: KI / Familien-Modus links neben Maximize/Minimize */
.chat-header-mode-switch {
    display: none;
    align-items: center;
    gap: 4px;
    flex-shrink: 0;
}

.chat-popup.active:not(.chat-popup-mobile-fullscreen) .chat-header-mode-switch {
    display: flex !important;
}

@media (max-width: 1024px) {
    .chat-header-mode-switch {
        display: none !important;
    }
}

.chat-header-mode-btn {
    position: relative;
    background: transparent;
    border: none;
    color: #ffffff;
    cursor: pointer;
    padding: 0 8px;
    margin: 8px 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 9999px;
    transition: background 0.2s ease, color 0.2s ease;
    width: auto;
    min-width: 44px;
    height: 32px;
    min-height: 32px;
    flex-shrink: 0;
    box-sizing: border-box;
    overflow: visible;
}

.chat-header-mode-btn-inner {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    pointer-events: none;
}

.chat-header-mode-btn:hover {
    background: rgba(255, 255, 255, 0.15);
    color: #ffffff;
}

.chat-header-mode-switch-icon {
    display: block;
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    opacity: 0.92;
}

.chat-header-mode-target-icon,
.chat-header-mode-btn .chat-nav-ai-icon {
    display: block;
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}

.chat-header-mode-btn svg {
    display: block;
}

/* KI-Stern im Header: .chat-nav-ai-icon ist für die linke Nav (absolute) — hier im Button zentrieren */
.chat-header-mode-btn .chat-nav-ai-icon {
    position: static;
    top: auto;
    left: auto;
    opacity: 1;
    transform: none;
    width: 20px !important;
    height: 20px !important;
}

.chat-header-mode-btn:hover .chat-nav-ai-icon,
.chat-header-mode-btn.chat-nav-switch-to-ai.active .chat-nav-ai-icon,
.chat-header-mode-btn.chat-nav-switch-to-ai.active:hover .chat-nav-ai-icon {
    transform: none;
}

.chat-popup:not(.ai-mode):not(.chat-popup-mobile-fullscreen) #chatNavSwitchToFamilyBtn {
    display: none !important;
}

.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) #chatNavSwitchToAiBtn {
    display: none !important;
}

/* KI-Archiv: linke Nav-Leiste (Desktop); im Familien-Modus ausgeblendet */
.chat-nav-ai-archived-slot {
    display: none;
    flex-direction: column;
    align-items: center;
    width: 100%;
    padding-top: 0;
    margin-top: 0;
    border-top: none;
    gap: 8px;
}

.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-ai-archived-slot {
    display: flex !important;
}

.chat-popup:not(.ai-mode) .chat-nav-ai-archived-slot {
    display: none !important;
}

/* Mobil KI-Vollbild: Archiv-Button in der Suchzeile (keine extra Zeile darüber) */
.ai-conversations-search-archive-btn {
    display: none;
    flex-shrink: 0;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border: 1px solid #e2e8f0;
    border-radius: 50%;
    background: #f8fafc;
    color: #1a1a1a;
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
}

.chat-popup.ai-mode.chat-popup-mobile-fullscreen .ai-conversations-search-archive-btn {
    display: flex !important;
}

.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .ai-conversations-search-archive-btn {
    display: none !important;
}

.ai-conversations-search-archive-btn.active {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    border-color: transparent !important;
    color: #fff !important;
}

.chat-popup.ai-mode .chat-nav-ai-archived-slot .chat-nav-btn.active {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    color: #fff !important;
}

body.dark-mode .ai-conversations-search-archive-btn {
    background: #1a1a1a;
    border-color: #1a1a1a;
    color: #e2e8f0;
}

body.dark-mode .ai-conversations-search-archive-btn.active {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    border-color: transparent;
    color: #fff !important;
}

/* KI-Symbol im Header: kein grauer Kreis wie bei .active — Füllung bleibt Gradient */
.chat-header-mode-btn.chat-nav-switch-to-ai.active,
.chat-nav-btn.chat-nav-switch-to-ai.chat-nav-btn.active {
    background: transparent !important;
    background-color: transparent !important;
    color: inherit !important;
}


/* Familien-Modus: KI-Listen-Suche und -Liste nicht einblenden (eine Suchleiste je Modus) */
.chat-popup:not(.ai-mode) #aiConversationsSearchContainer,
.chat-popup:not(.ai-mode) #aiConversationsList {
    display: none !important;
}

.chat-navigation-section .chat-nav-btn .nav-label {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-top .chat-nav-btn[data-nav="notes"],
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-top .chat-nav-btn[data-nav="newContacts"],
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-top .chat-nav-btn[data-nav="archived"],
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-top .chat-nav-btn[data-nav="calls"] {
    display: none !important;
}

.chat-popup.ai-mode .chat-stories-wrapper {
    display: none !important;
}

.chat-nav-bottom {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-top: auto;
    padding: 0;
    width: 100%;
}

.chat-nav-bottom .chat-nav-profile {
    margin-top: auto;
}

.chat-nav-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border: none;
    background: transparent;
    background-color: transparent;
    color: #6c757d;
    cursor: pointer;
    border-radius: 50%;
    transition: background-color 0.15s ease, color 0.15s ease;
    padding: 0;
    flex-shrink: 0;
    overflow: visible;
    position: relative;
}

.chat-nav-ai {
    position: relative;
    width: 48px;
    height: 48px;
}

.chat-nav-btn:hover {
    background: #f8f9fa;
    background-color: #f8f9fa;
    color: #1a1a1a;
}

.chat-nav-btn:hover svg {
    color: #1a1a1a;
}

.chat-nav-ai:hover svg {
    color: #6c757d !important;
}

/* Selected section: dark grey circle + white icon (like mobile) */
.chat-nav-btn.active {
    background: #1a1a1a;
    background-color: #1a1a1a;
    color: #ffffff;
}

.chat-nav-btn.active:hover {
    background: #1a1a1a;
    background-color: #1a1a1a;
    color: #ffffff;
}

.chat-nav-btn.active svg {
    color: #ffffff;
}

/* KI-Modus: aktive Sektion (Chat, Einstellungen, …) = gleiches Violett wie KI-Badge */
.chat-popup.ai-mode .chat-nav-btn.active {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    background-color: #6366f1;
    color: #ffffff;
}

.chat-popup.ai-mode .chat-nav-btn.active:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
    background-color: #4f46e5;
    color: #ffffff;
}

.chat-popup.ai-mode .chat-nav-btn.active svg {
    color: #ffffff;
}

.chat-popup.ai-mode .chat-navigation-section {
    border: none;
    border-right: none;
    box-shadow: none;
    outline: none;
}

/* KI / Vollbild / Snap: durchgehende Säulenfarbe, keine weißen Kanten um rail-back */
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-navigation-section,
.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) .chat-navigation-section,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen) .chat-navigation-section {
    background: var(--kinma-chat-nav-island-bg, #1a1a1a);
}

.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-back,
.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-back,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-back {
    inset: -2px;
    border: none;
    outline: none;
    box-shadow: none;
}

.chat-popup.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-front,
.chat-popup.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-front,
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-nav-rail-front {
    box-shadow: none;
    border: none;
    outline: none;
}

.chat-popup.ai-mode.chat-popup-header-dbl-fullscreen:not(.chat-popup-mobile-fullscreen)
    .chat-popup-header-drag-handle,
.chat-popup.ai-mode.kinma-chat-popup--wall-snapped:not(.chat-popup-mobile-fullscreen)
    .chat-popup-header-drag-handle {
    background: var(--kinma-chat-nav-island-bg, #4f46e5);
}

.chat-nav-btn svg {
    width: 22px;
    height: 22px;
    overflow: visible;
    transition: color 0.15s ease;
    color: inherit;
}

.chat-nav-btn.chat-nav-btn-disabled,
.chat-nav-btn.chat-nav-btn-disabled:hover {
    opacity: 0.45;
    cursor: not-allowed;
    transform: none;
    background: transparent;
    color: #9ca3af;
}

.chat-nav-ai {
    overflow: visible;
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
}

.chat-nav-stories {
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-nav-stories .chat-nav-stories-icon {
    display: block;
    width: 22px;
    height: 22px;
    flex-shrink: 0;
    min-width: 22px;
    min-height: 22px;
}

.chat-nav-ai svg {
    width: 22px;
    height: 22px;
    transition: color 0.15s ease;
    display: block;
    margin: 0;
    flex-shrink: 0;
}

.chat-nav-ai-icon,
.chat-nav-family-icon {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    transition: opacity 0.3s ease, transform 0.3s ease;
    width: 22px !important;
    height: 22px !important;
    margin: 0;
    padding: 0;
}

.chat-nav-ai-icon {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
}

.chat-nav-family-icon {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.8);
}

.chat-popup.ai-mode .chat-nav-ai .chat-nav-ai-icon {
    opacity: 0;
    transform: translate(-50%, -50%) scale(0.8);
}

.chat-popup.ai-mode .chat-nav-ai .chat-nav-family-icon {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1);
    display: block !important;
}

.chat-nav-ai svg path {
    fill: url(#aiIconGradient);
}

.chat-nav-ai:hover {
    background: #f8f9fa;
    background-color: #f8f9fa;
    color: #1a1a1a;
}

.chat-nav-ai:hover .chat-nav-ai-icon,
.chat-nav-ai:hover .chat-nav-family-icon {
    transform: translate(-50%, -50%);
}

/* AI Button - Active state with animated gradient background */
.chat-nav-ai.active {
    background: linear-gradient(
        90deg,
        #6366f1 0%,
        #8b5cf6 20%,
        #ec4899 40%,
        #fb923c 60%,
        #22c55e 80%,
        #3b82f6 100%,
        #6366f1 100%
    ) !important;
    background-size: 300% 100% !important;
    animation: aiButtonGradientMove 3s ease infinite, aiButtonHueRotate 3s ease infinite !important;
    color: #ffffff !important;
}

.chat-nav-ai.active:hover {
    animation: aiButtonGradientMove 3s ease infinite, aiButtonHueRotate 3s ease infinite !important;
}

/* AI Button Icon - White when active */
.chat-nav-ai.active svg path {
    fill: #ffffff !important;
    opacity: 1 !important;
}

.chat-nav-ai.active .chat-nav-ai-icon,
.chat-nav-ai.active .chat-nav-family-icon {
    transform: translate(-50%, -50%) scale(1);
}

.chat-nav-ai.active:hover .chat-nav-ai-icon,
.chat-nav-ai.active:hover .chat-nav-family-icon {
    transform: translate(-50%, -50%) scale(1);
}

/* AI Button Gradient Animations */
@keyframes aiButtonGradientMove {
    0% { background-position: 0% 50%; }
    20% { background-position: 100% 50%; }
    40% { background-position: 200% 50%; }
    60% { background-position: 100% 50%; }
    80% { background-position: 0% 50%; }
    100% { background-position: 0% 50%; }
}

@keyframes aiButtonHueRotate {
    0% { filter: hue-rotate(0deg); }
    20% { filter: hue-rotate(60deg); }
    40% { filter: hue-rotate(120deg); }
    60% { filter: hue-rotate(180deg); }
    80% { filter: hue-rotate(240deg); }
    100% { filter: hue-rotate(300deg); }
}

.chat-nav-btn[data-badge]::after {
    content: attr(data-badge);
    position: absolute;
    top: 6px;
    right: 6px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    background: #dc3545;
    color: white;
    border-radius: 9px;
    font-size: 11px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 2px solid #ffffff;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
    z-index: 10;
    line-height: 1;
}

.chat-nav-btn:focus-visible {
    outline: 2px solid #4a90e2;
    outline-offset: 2px;
}

.chat-nav-profile:focus-visible {
    outline: 2px solid #667eea;
    outline-offset: 2px;
    border-radius: 50%;
}

.chat-nav-settings {
    position: relative;
}

.chat-nav-profile {
    position: relative;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    cursor: pointer;
    margin-top: 0;
    flex-shrink: 0;
    overflow: visible;
}

.chat-nav-profile-avatar {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    overflow: hidden;
    background: #1a1a1a;
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 18px;
    border: 2px solid transparent;
}

.chat-nav-profile-avatar img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    border-radius: 50%;
}

.chat-nav-profile.active {
    background: #e9ecef;
    border-radius: 50%;
}

.chat-nav-profile:hover,
.chat-nav-profile:hover .chat-nav-profile-avatar,
.chat-nav-profile:active .chat-nav-profile-avatar,
.chat-nav-profile:hover .chat-nav-profile-status,
.chat-nav-profile:active .chat-nav-profile-status {
    transform: none;
    box-shadow: none;
}

.chat-nav-profile-status {
    /* Größe/Farbe: chat-box-v2.css (--kinma-avatar-size am .chat-nav-profile) */
}

.chat-nav-profile-status[data-status="offline"] {
    background: #6c757d;
}

.chat-nav-profile-status[data-status="away"] {
    background: #ffc107;
}

.chat-notifications-view {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    overflow: hidden;
}

.chat-notifications-header {
    padding: 20px 24px;
    border-bottom: 1px solid #e9ecef;
    background: #ffffff;
}

.chat-notifications-header h2 {
    margin: 0;
    font-size: 24px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-notifications-list {
    flex: 1;
    overflow-y: auto;
    padding: 16px;
    display: flex;
    flex-direction: column;
}

.chat-notifications-list.is-empty {
    justify-content: center;
    align-items: center;
}

.chat-stories-view {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    overflow: hidden;
    min-width: 0;
    min-height: 200px;
}

.chat-stories-view {
    flex: 1;
    position: relative;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    overflow: hidden;
    min-width: 0;
    min-height: 200px;
}

/* Fixed "Neue Geschichte erstellen" Button unten rechts */
.chat-stories-create-fab {
    position: absolute;
    right: 16px;
    bottom: 16px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    background: #1a1a1a;
    border: none;
    border-radius: 24px;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    transition: background 0.2s ease;
    z-index: 10;
}
.chat-stories-create-fab:hover {
    background: #1a1a1a;
}

/* Story-Button als Kreis (in der Story-Zeile) */
.chat-stories-add-circle {
    width: 56px !important;
    height: 56px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    min-width: 56px;
    min-height: 56px;
    background: #adb5bd !important;
    color: #fff !important;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
}
.chat-stories-add-circle:hover {
    background: #868e96 !important;
}
.chat-stories-add-circle .chat-stories-create-fab-label {
    display: none;
}
.chat-stories-add-circle svg {
    margin: 0;
}

.chat-stories-create-fab svg {
    flex-shrink: 0;
}
.chat-stories-create-fab-label {
    white-space: nowrap;
}

.chat-stories-tabs {
    display: none;
}

.chat-stories-tab {
    padding: 12px 20px;
    font-size: 14px;
    font-weight: 600;
    color: #6c757d;
    background: transparent;
    border: none;
    border-bottom: 3px solid transparent;
    cursor: pointer;
    transition: color 0.2s, border-color 0.2s, background 0.2s;
    margin-bottom: -1px;
    border-radius: 8px 8px 0 0;
}

.chat-stories-tab:hover {
    color: #1a1a1a;
    background: rgba(0, 0, 0, 0.04);
}

.chat-stories-tab.active {
    color: #1a1a1a;
    background: #ffffff;
    border-bottom-color: #1a1a1a;
    box-shadow: 0 -1px 0 0 #fff;
}

.chat-stories-panel {
    flex: 1;
    overflow-y: auto;
    overflow-x: hidden;
    display: flex;
    flex-direction: column;
    min-height: 0;
}

.chat-stories-panel-list {
    display: flex;
    flex-direction: column;
    padding-bottom: 20px;
}

.chat-stories-panel-create {
    display: none;
    flex-direction: column;
    overflow-y: auto;
    padding: 20px;
    background: #ffffff;
}

.chat-story-creation-in-tab {
    display: flex;
    flex-direction: column;
    gap: 20px;
    max-width: 480px;
    margin: 0 auto;
    width: 100%;
}

.chat-story-creation-in-tab .chat-story-creation-upload,
.chat-story-creation-in-tab .chat-story-creation-form {
    width: 100%;
}

.chat-story-creation-in-tab .chat-story-creation-actions {
    position: static;
    margin-top: 8px;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.chat-stories-view-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
    border-bottom: 1px solid #e9ecef;
    background: #f8f9fa;
    flex-shrink: 0;
}

.chat-stories-view-label {
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-stories-view-header .chat-stories-add-btn-header {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: none;
    background: #1a1a1a;
    color: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background 0.15s ease;
}

.chat-stories-view-header .chat-stories-add-btn-header:hover {
    background: #1a1a1a;
}

/* Eine Reihe: Pillbar (Gedanken) + Stories + Add */
.chat-stories-single-row {
    display: flex;
    align-items: center;
    gap: 0;
    flex-shrink: 0;
    min-height: 64px;
    padding: 8px 14px;
    border-bottom: 1px solid #e9ecef;
    background: #fff;
}

.chat-stories-pillbar {
    width: 160px;
    min-width: 120px;
    height: 36px;
    padding: 0 14px;
    border: 1px solid #dee2e6;
    border-radius: 18px;
    font-size: 14px;
    color: #1a1a1a;
    background: #f5f6f8;
    transition: border-color 0.15s ease, background 0.15s ease;
    outline: none;
}
.chat-stories-add-unit .chat-stories-pillbar {
    width: 56px;
    min-width: 56px;
    height: 32px;
    padding: 0 8px;
    font-size: 13px;
    border-radius: 16px;
}
.chat-stories-pillbar::placeholder {
    color: #adb5bd;
}
.chat-stories-pillbar:focus {
    border-color: #868e96;
    background: #fff;
}
.chat-stories-pillbar:not(:placeholder-shown) {
    background: #fff;
    border-color: #adb5bd;
}

.chat-stories-feed-row {
    flex-shrink: 0;
    overflow-x: auto;
    overflow-y: visible;
    padding: 10px 16px 14px;
    min-height: 0;
    border-bottom: 1px solid #e9ecef;
    background: #f8f9fa;
}
.chat-stories-feed-row .chat-stories-feed {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 12px;
    align-items: flex-end;
}
.chat-stories-feed-row .chat-stories-feed-empty {
    padding: 8px 0 4px;
    text-align: left;
    font-size: 13px;
    color: #6c757d;
    line-height: 1.4;
}

.chat-stories-single-row .chat-stories-strip {
    flex: 1;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 10px 0 12px;
    -webkit-overflow-scrolling: touch;
}
.chat-stories-single-row .chat-stories-strip .chat-stories-scroll-header {
    display: inline-flex;
    align-items: flex-end;
    gap: 10px;
    min-height: 48px;
    padding: 0 8px 0 10px;
    box-sizing: border-box;
}
.chat-stories-single-row .chat-stories-add-wrap {
    flex-shrink: 0;
    padding-left: 10px;
    display: flex;
    align-items: center;
}
.chat-stories-add-unit {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
}
.chat-stories-add-unit .chat-stories-pillbar {
    width: 56px;
    min-width: 56px;
    height: 32px;
    padding: 0 8px;
    font-size: 13px;
    border-radius: 16px;
}

/* Oben: Gedanken-Reihe (über den Stories) – bleibt für kompakte Ansicht */
.chat-stories-gedanken-row {
    flex-shrink: 0;
    border-bottom: 1px solid #e9ecef;
    background: #f8f9fa;
}

.chat-stories-gedanken-strip {
    overflow-x: auto;
    overflow-y: hidden;
    padding: 12px 16px;
    -webkit-overflow-scrolling: touch;
    display: flex;
    align-items: flex-end;
    gap: 16px;
    flex-wrap: nowrap;
}

/* Gedanken „Hinzufügen“-Button: Profilbild + leere Gedankenblase, leicht ausgegraut */
.chat-gedanken-add-btn {
    flex-shrink: 0;
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0;
    opacity: 0.9;
    transition: opacity 0.15s ease;
}
.chat-gedanken-add-btn:hover {
    opacity: 1;
}
.chat-gedanken-add-bubble {
    display: block;
    width: 52px;
    height: 36px;
    margin-bottom: -10px;
    margin-left: 6px;
    background: #e9ecef;
    border: 1px solid #dee2e6;
    border-radius: 14px 14px 14px 4px;
    position: relative;
}
.chat-gedanken-add-bubble::before {
    content: '';
    position: absolute;
    left: 10px;
    bottom: -6px;
    width: 12px;
    height: 12px;
    background: #e9ecef;
    border-left: 1px solid #dee2e6;
    border-bottom: 1px solid #dee2e6;
    border-radius: 0 0 0 6px;
    transform: rotate(-45deg);
}
.chat-gedanken-add-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 16px;
    color: #fff;
}

/* Stories add choice modal (single add button flow) */
.chat-stories-create-choice-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.35);
    z-index: 10000;
}
.chat-stories-create-choice-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: min(92vw, 380px);
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    z-index: 10001;
    display: flex;
    flex-direction: column;
}
.chat-stories-create-choice-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e9ecef;
}
.chat-stories-create-choice-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}
.chat-stories-create-choice-close {
    width: 36px;
    height: 36px;
    border: none;
    background: transparent;
    color: #6c757d;
    cursor: pointer;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.chat-stories-create-choice-close:hover {
    background: #f1f3f5;
    color: #1a1a1a;
}
.chat-stories-create-choice-body {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 16px 20px 20px;
}
.chat-stories-create-choice-btn {
    width: 100%;
    padding: 12px 14px;
    border-radius: 10px;
    border: 1px solid #dee2e6;
    background: #fff;
    color: #1a1a1a;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    transition: background 0.2s ease, border-color 0.2s ease;
}
.chat-stories-create-choice-btn:hover {
    background: #f8f9fa;
    border-color: #ced4da;
}
.chat-stories-create-choice-btn.chat-stories-create-choice-btn-primary {
    background: #1a1a1a;
    border-color: #1a1a1a;
    color: #fff;
}
.chat-stories-create-choice-btn.chat-stories-create-choice-btn-primary:hover {
    background: #1a1a1a;
    border-color: #1a1a1a;
}

/* Gedanken erstellen Modal */
.chat-gedanken-modal-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.4);
    z-index: 10000;
}
.chat-gedanken-modal {
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 90%;
    max-width: 420px;
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
    z-index: 10001;
    display: flex;
    flex-direction: column;
    max-height: 85vh;
}
.chat-gedanken-modal-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e9ecef;
}
.chat-gedanken-modal-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}
.chat-gedanken-modal-close {
    width: 36px;
    height: 36px;
    border: none;
    background: transparent;
    color: #6c757d;
    cursor: pointer;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.chat-gedanken-modal-close:hover {
    background: #f1f3f5;
    color: #1a1a1a;
}
.chat-gedanken-modal-body {
    padding: 20px;
}
.chat-gedanken-modal-body textarea {
    width: 100%;
    min-height: 120px;
    padding: 12px 14px;
    border: 1px solid #dee2e6;
    border-radius: 10px;
    font-size: 15px;
    line-height: 1.5;
    resize: vertical;
    box-sizing: border-box;
}
.chat-gedanken-modal-body textarea:focus {
    outline: none;
    border-color: #1a1a1a;
}
.chat-gedanken-modal-footer {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    padding: 16px 20px;
    border-top: 1px solid #e9ecef;
}
.chat-gedanken-modal-cancel {
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 500;
    color: #6c757d;
    background: #f1f3f5;
    border: none;
    border-radius: 8px;
    cursor: pointer;
}
.chat-gedanken-modal-cancel:hover {
    background: #e9ecef;
}
.chat-gedanken-modal-submit {
    padding: 10px 18px;
    font-size: 14px;
    font-weight: 600;
    color: #fff;
    background: #1a1a1a;
    border: none;
    border-radius: 8px;
    cursor: pointer;
}
.chat-gedanken-modal-submit:hover {
    background: #1a1a1a;
}

/* Rückruf-Bestätigung: nur innerhalb der Chatbox (nicht fullscreen) */
#chatPopup .chat-callback-modal-overlay {
    position: absolute;
    inset: 0;
    z-index: 10000;
    background: rgba(0, 0, 0, 0.4);
}
#chatPopup .chat-callback-modal {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 10001;
}
#chatPopup .chat-callback-modal-text {
    margin: 0;
    font-size: 15px;
    color: #1a1a1a;
}

/* Musik-Gedanken Modal */
.chat-music-gedanken-modal .chat-gedanken-modal-body {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.chat-music-gedanken-source-tabs {
    display: flex;
    gap: 4px;
    margin-bottom: 4px;
}
.chat-music-tab {
    padding: 8px 14px;
    font-size: 14px;
    font-weight: 500;
    color: #6c757d;
    background: #f1f3f5;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    cursor: pointer;
}
.chat-music-tab.active {
    color: #1a1a1a;
    background: #fff;
    border-color: #1a1a1a;
}
.chat-music-gedanken-pane {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.chat-music-label {
    font-size: 13px;
    font-weight: 500;
    color: #1a1a1a;
}
.chat-music-select,
.chat-music-input {
    padding: 10px 12px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}
.chat-music-select {
    width: 100%;
    max-width: 240px;
}
.chat-music-input {
    width: 100%;
}
.chat-music-file {
    font-size: 14px;
    padding: 8px 0;
}
.chat-music-textarea {
    width: 100%;
    min-height: 60px;
    padding: 10px 12px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    font-size: 14px;
    resize: vertical;
    box-sizing: border-box;
}
.chat-music-textarea:focus,
.chat-music-input:focus,
.chat-music-select:focus {
    outline: none;
    border-color: #1a1a1a;
}

.chat-stories-gedanken-strip .chat-stories-feed {
    display: inline-flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: 16px;
    align-items: flex-end;
    min-height: 100px;
}

.chat-stories-gedanken-strip .chat-stories-feed-empty {
    padding: 16px 0;
    text-align: left;
    min-width: 100%;
}

.chat-stories-gedanken-strip .chat-gedanke-card {
    flex-shrink: 0;
}

/* Oben: eine Zeile – Stories-Strip (scroll) + Add-Button rechts, gleiches Level */
.chat-stories-top-row {
    display: flex;
    align-items: center;
    gap: 0;
    flex-shrink: 0;
    min-height: 88px;
    padding: 12px 0 12px 16px;
    border-bottom: 1px solid #e9ecef;
    background: #fff;
}

/* Kompaktere Rows, wenn eine Story geöffnet ist */
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-single-row {
    min-height: 48px;
    padding: 6px 12px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-pillbar {
    width: 48px;
    min-width: 48px;
    height: 28px;
    padding: 0 6px;
    font-size: 12px;
    border-radius: 14px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-story-item .chat-stories-pillbar-wrap {
    width: 48px;
    min-width: 48px;
    height: 24px;
    padding: 0 4px;
    border-radius: 12px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-story-item .chat-stories-pillbar-wrap .chat-stories-pillbar {
    height: 20px;
    font-size: 12px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-story-item .chat-stories-pillbar-music-btn {
    width: 20px;
    height: 20px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-story-item .chat-stories-pillbar-music-btn svg {
    width: 12px;
    height: 12px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-single-row .chat-stories-strip {
    padding: 0 8px 0 10px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-strip .chat-stories-scroll-header {
    min-height: 40px;
    gap: 8px;
    padding: 0 6px 0 8px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-story-item {
    transform: scale(0.72);
    transform-origin: left center;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-add-wrap {
    padding-left: 8px;
    padding-right: 12px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-add-circle {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px;
    min-height: 40px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-add-circle svg {
    width: 18px;
    height: 18px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-feed-row {
    padding: 4px 12px;
}
.chat-stories-panel-list.chat-stories-rows-compact .chat-stories-feed-empty {
    padding: 4px 0;
    font-size: 12px;
}

.chat-stories-strip {
    flex: 1;
    min-width: 0;
    overflow-x: auto;
    overflow-y: hidden;
    padding-right: 8px;
    -webkit-overflow-scrolling: touch;
}

.chat-stories-strip .chat-stories-scroll-header {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    min-height: 64px;
    padding: 0 4px;
}

.chat-stories-add-wrap {
    flex-shrink: 0;
    padding-left: 12px;
    padding-right: 16px;
    align-self: center;
}

/* Add-Button in der Zeile (nicht mehr fixed unten rechts) */
.chat-stories-add-row-btn {
    position: static !important;
    right: auto;
    bottom: auto;
}

/* Strip: bei leerem Zustand zentrieren, kein Scroll nötig */
.chat-stories-strip:has(.chat-stories-empty) {
    overflow: visible;
    display: flex;
    align-items: center;
    justify-content: center;
}
.chat-stories-strip:has(.chat-stories-empty) .chat-stories-scroll-header {
    flex: 1;
    justify-content: center;
}

/* ========== Gedanken-Karte: Profilbild + Gedankenblase (überlappend) ========== */
.chat-gedanke-card {
    display: inline-flex;
    flex-direction: column;
    align-items: flex-start;
    max-width: 320px;
    position: relative;
}

.chat-gedanke-bubble-wrap {
    position: relative;
    z-index: 2;
    margin-bottom: -12px;
    margin-left: 8px;
}

.chat-gedanke-bubble {
    background: #fff;
    border: 1px solid #dee2e6;
    border-radius: 16px 16px 16px 4px;
    padding: 10px 14px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06);
    max-width: 280px;
    position: relative;
}

.chat-gedanke-bubble::before {
    content: '';
    position: absolute;
    left: 12px;
    bottom: -8px;
    width: 16px;
    height: 16px;
    background: #fff;
    border-left: 1px solid #dee2e6;
    border-bottom: 1px solid #dee2e6;
    border-radius: 0 0 0 8px;
    transform: rotate(-45deg);
    box-shadow: 2px 2px 4px rgba(0,0,0,0.04);
}

.chat-gedanke-bubble-text {
    font-size: 14px;
    line-height: 1.4;
    color: #1a1a1a;
    max-height: 3.6em;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    transition: max-height 0.2s ease, -webkit-line-clamp 0.2s ease;
}

.chat-gedanke-card.is-hover-bubble .chat-gedanke-bubble-text {
    max-height: none;
    -webkit-line-clamp: unset;
}

.chat-gedanke-bubble-music {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 14px;
    color: #1a1a1a;
}

.chat-gedanke-bubble-music .chat-gedanke-music-title {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 200px;
}
.chat-gedanke-bubble-music .chat-gedanke-music-link {
    color: #0d6efd;
    text-decoration: none;
}
.chat-gedanke-bubble-music .chat-gedanke-music-link:hover {
    text-decoration: underline;
    color: #0a58ca;
}
.chat-gedanke-bubble-music .chat-gedanke-music-text {
    font-size: 12px;
    color: #6c757d;
    margin-top: 4px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 200px;
}

.chat-gedanke-avatar-wrap {
    position: relative;
    z-index: 1;
    flex-shrink: 0;
}

.chat-gedanke-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 16px;
    color: #fff;
}

.chat-stories-feed-empty {
    text-align: center;
    padding: 32px 16px;
    color: #6c757d;
    font-size: 14px;
}

.chat-stories-view-scroll {
    flex: 1;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 16px;
    min-height: 0;
}

.chat-stories-view .chat-stories-scroll-header {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 80px;
    padding: 0 4px;
}

.chat-stories-view .chat-stories-scroll-header {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 80px;
    padding: 0 4px;
}

/* Stories list empty state - improved design */
.chat-stories-view-scroll:has(.chat-stories-empty) {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 24px;
    min-height: 280px;
}

.chat-stories-empty {
    width: 100%;
    max-width: 360px;
}

.chat-stories-empty-card {
    background: #ffffff;
    border: 1px solid #dee2e6;
    border-radius: 16px;
    padding: 32px 24px;
    text-align: center;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

.chat-stories-empty-icon {
    color: #adb5bd;
    margin-bottom: 16px;
}

.chat-stories-empty-icon svg {
    display: block;
    margin: 0 auto;
}

.chat-stories-empty-title {
    margin: 0 0 8px 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-stories-empty-desc {
    margin: 0 0 20px 0;
    font-size: 14px;
    color: #6c757d;
    line-height: 1.5;
}

.chat-stories-empty-cta {
    display: inline-block;
    padding: 12px 24px;
    font-size: 15px;
    font-weight: 600;
    color: #ffffff !important;
    background: #1a1a1a !important;
    border: none !important;
    border-radius: 10px;
    cursor: pointer;
    transition: background 0.15s ease;
    box-shadow: 0 1px 4px rgba(26, 26, 26, 0.15);
    appearance: none;
    -webkit-appearance: none;
}

.chat-stories-empty-cta:hover {
    background: #1a1a1a !important;
}

.chat-calls-view {
    flex: 1;
    display: flex;
    flex-direction: column;
    background: #ffffff;
    overflow: hidden;
    min-width: 0;
    min-height: 200px;
    position: relative;
}

.chat-calls-header {
    padding: 20px 24px;
    border-bottom: 1px solid #e9ecef;
    background: #ffffff;
}

.chat-calls-header h2 {
    margin: 0;
    font-size: 24px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-calls-columns {
    flex: 1;
    display: flex;
    overflow: hidden;
    min-height: 200px;
}

.chat-calls-history {
    flex: 1;
    min-height: 0;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    position: relative;
}

.chat-calls-col {
    flex: 1;
    display: flex;
    flex-direction: column;
    min-width: 0;
    border-right: 1px solid #e9ecef;
}

.chat-calls-col:last-child {
    border-right: none;
}

.chat-calls-col-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    padding: 8px 10px;
    flex-shrink: 0;
}

.chat-calls-col-header-prev,
.chat-calls-col-header-next {
    display: none;
}

.chat-calls-col-header-center {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
}

.chat-calls-col-header .chat-calls-col-icon {
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-calls-col-header .chat-calls-col-icon svg {
    display: block;
}

.chat-calls-col-header-called {
    color: #0d6efd;
    background: rgba(13, 110, 253, 0.08);
}

.chat-calls-col-header-accepted {
    color: #198754;
    background: rgba(25, 135, 84, 0.08);
}

.chat-calls-col-header-declined {
    color: #dc3545;
    background: rgba(220, 53, 69, 0.08);
}

.chat-calls-col-header-missed {
    color: #6c757d;
    background: rgba(108, 117, 125, 0.08);
}

.chat-calls-col-label {
    font-size: 12px;
    font-weight: 600;
    text-align: center;
}

.chat-calls-col-list {
    flex: 1;
    overflow-y: auto;
    padding: 8px;
    padding-bottom: calc(88px + env(safe-area-inset-bottom, 0px));
    box-sizing: border-box;
    min-height: 120px;
}

.chat-calls-col-list.is-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #adb5bd;
    font-size: 13px;
}

.chat-calls-empty-msg {
    padding: 12px 16px;
    text-align: center;
    max-width: 180px;
    line-height: 1.4;
}

.chat-calls-list {
    flex: 1;
    overflow-y: auto;
    padding: 16px;
}

.chat-calls-date-group {
    margin-bottom: 12px;
}

.chat-calls-date-header {
    padding: 4px 0;
    font-size: 10px;
    font-weight: 600;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 4px;
    text-align: center;
}

.chat-calls-date-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.chat-call-item {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 12px;
    border-radius: 9999px;
    cursor: pointer;
    transition: background 0.2s ease;
    margin-bottom: 0;
}

.chat-call-item:hover {
    background: #f8f9fa;
}

.chat-call-item.missed {
    background: rgba(108, 117, 125, 0.08);
}

.chat-call-item.missed:hover {
    background: rgba(108, 117, 125, 0.14);
}

.chat-call-item.declined {
    background: rgba(220, 53, 69, 0.06);
}

.chat-call-item.declined:hover {
    background: rgba(220, 53, 69, 0.12);
}

.chat-call-item.answered {
    background: rgba(40, 167, 69, 0.05);
}

.chat-call-item.answered:hover {
    background: rgba(40, 167, 69, 0.1);
}

/* Voice Mails: Kreis-Button rechts im unteren Dock (Position: chat-content-area .chat-calls-voicemail-fab-wrap) */
.chat-calls-voicemail-fab-wrap {
    padding: 0;
}

.chat-calls-voicemail-row {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 12px 24px;
    border: none;
    border-radius: 9999px;
    background: #1a1a1a;
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
    flex-shrink: 0;
    text-align: center;
    position: relative;
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.25);
}

.chat-calls-voicemail-fab.chat-calls-voicemail-row {
    width: 52px;
    height: 52px;
    min-width: 52px;
    min-height: 52px;
    padding: 0;
    border-radius: 50%;
    gap: 0;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.28);
}

.chat-calls-voicemail-fab .chat-calls-voicemail-row-label,
.chat-calls-voicemail-fab .chat-calls-voicemail-row-chevron {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.chat-calls-voicemail-row:hover {
    background: #1a1a1a;
    transform: translateY(-1px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.chat-calls-voicemail-fab.chat-calls-voicemail-row:hover {
    transform: translateY(-2px);
}

.chat-calls-voicemail-row:active {
    transform: translateY(0);
}

.chat-calls-voicemail-fab.chat-calls-voicemail-row:active {
    transform: translateY(0);
}

.chat-calls-voicemail-row-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    color: rgba(255, 255, 255, 0.95);
}

.chat-calls-voicemail-row-label {
    letter-spacing: 0.02em;
}

.chat-calls-voicemail-row-badge {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 20px;
    height: 20px;
    padding: 0 6px;
    border-radius: 10px;
    background: #fff;
    color: #1a1a1a;
    font-size: 11px;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.chat-calls-voicemail-row-chevron {
    display: flex;
    color: rgba(255, 255, 255, 0.9);
    transition: transform 0.2s ease;
}

.chat-calls-voicemail-row:not(.chat-calls-voicemail-fab):hover .chat-calls-voicemail-row-chevron {
    transform: translateY(2px);
}

.chat-calls-voicemail-panel[aria-hidden="true"] {
    display: none !important;
}

.chat-calls-voicemail-panel[aria-hidden="false"] {
    display: flex !important;
}

.chat-calls-voicemail-panel {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    flex-direction: column;
    background: #fff;
    z-index: 20;
    overflow: hidden;
}

/* Expanded: Panel als Overlay – Anrufliste und Button bleiben im Layout */
.chat-calls-view.voicemail-expanded .chat-calls-voicemail-panel {
    display: flex !important;
    flex-direction: column !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 0;
    overflow: hidden;
    background: #fff;
    z-index: 30;
    box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.06);
}

/* Panel header: hell wie restliche App, nur Zurück-Button + optional Titel */
.chat-calls-voicemail-panel-header {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 12px 16px;
    background: #fff;
    flex-shrink: 0;
    position: relative;
    border-bottom: 1px solid #e9ecef;
}

.chat-calls-voicemail-back {
    position: absolute;
    left: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: #1a1a1a;
    cursor: pointer;
    transition: background 0.2s ease, color 0.2s ease;
}

.chat-calls-voicemail-back:hover {
    background: #f3f4f6;
    color: #1a1a1a;
}

.chat-calls-voicemail-panel-title {
    margin: 0;
    font-size: 17px;
    font-weight: 600;
    color: #1a1a1a;
    letter-spacing: 0.01em;
}

.chat-calls-voicemail-list {
    flex: 1 1 0%;
    min-height: 0;
    overflow-y: auto;
    padding: 16px;
    background: #fff;
    display: flex;
    flex-direction: column;
}

/* Empty State: ohne Karte/Rahmen, wie andere leere Zustände */
.chat-calls-voicemail-empty {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    flex: 1;
    min-height: 200px;
    text-align: center;
    padding: 24px 16px;
    background: transparent;
}

.chat-calls-voicemail-empty-icon {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: #f3f4f6;
    color: #9ca3af;
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-calls-voicemail-empty-icon svg {
    width: 24px;
    height: 24px;
}

.chat-calls-voicemail-empty-title {
    margin: 0 0 8px 0;
    font-size: 16px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-calls-voicemail-empty-hint {
    margin: 0;
    font-size: 14px;
    color: #6b7280;
    max-width: 280px;
    line-height: 1.5;
}

.chat-call-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #e9ecef;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.chat-call-avatar-initials {
    font-size: 12px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-call-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.chat-call-name {
    font-size: 13px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-call-details {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    color: #6c757d;
}

.chat-call-icon {
    font-size: 14px;
}

.chat-call-direction {
    font-size: 12px;
}

.chat-call-status {
    font-weight: 500;
}

.chat-call-item.missed .chat-call-status {
    color: #6c757d;
}

.chat-call-item.declined .chat-call-status {
    color: #dc3545;
}

.chat-call-item.answered .chat-call-status {
    color: #28a745;
}

.chat-call-duration {
    color: #6c757d;
    font-weight: 400;
}

.chat-call-time {
    font-size: 11px;
    color: #6c757d;
    white-space: nowrap;
    flex-shrink: 0;
}

.chat-call-item.unread {
    background: rgba(220, 53, 69, 0.1);
    border-left: 3px solid #dc3545;
}

.chat-call-item.unread:hover {
    background: rgba(220, 53, 69, 0.15);
}

.chat-user-profile-avatar {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 18px;
    flex-shrink: 0;
}

.chat-user-profile-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.chat-user-profile-name {
    font-size: 14px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-user-profile-status-wrapper {
    display: flex;
    align-items: center;
    gap: 6px;
}

.chat-user-profile-status-indicator {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    transition: background-color 0.3s ease;
}

.chat-user-profile-status-indicator[data-status="green"] {
    background-color: #28a745;
}

.chat-user-profile-status-indicator[data-status="yellow"] {
    background-color: #ffc107;
}

.chat-user-profile-status-indicator[data-status="red"] {
    background-color: #dc3545;
}

.chat-user-profile-status-indicator[data-status="offline"],
.chat-user-profile-status-indicator[data-status="gray"] {
    background-color: #9ca3af;
}

.chat-user-profile-status {
    font-size: 12px;
    color: #6c757d;
    white-space: nowrap;
}

.chat-user-profile-settings {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    color: #6c757d;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.chat-user-profile-settings:hover {
    background: #e9ecef;
    color: #1a1a1a;
    border-color: #adb5bd;
}

.chat-user-profile-settings svg {
    width: 18px;
    height: 18px;
}

.chat-ai-assistant-btn:active {
    transform: translateY(0);
    box-shadow: 0 2px 4px rgba(99, 102, 241, 0.2);
}

.chat-ai-assistant-btn svg {
    flex-shrink: 0;
}

.ai-chat-header {
    cursor: default !important;
    position: relative;
}

.ai-chat-header:hover {
    background: transparent !important;
}

/* Voice button in AI chat header */
.ai-chat-voice-header-btn {
    background: rgba(255, 255, 255, 0.15);
    border: 1.5px solid rgba(255, 255, 255, 0.4);
    width: 36px;
    height: 36px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.15s ease, transform 0.15s ease, box-shadow 0.15s ease;
    color: #ffffff;
    flex-shrink: 0;
}

.ai-chat-voice-header-btn:hover {
    background: rgba(255, 255, 255, 0.28);
    transform: scale(1.08);
    box-shadow: 0 0 0 4px rgba(255, 255, 255, 0.12);
}

.ai-chat-voice-header-btn:active {
    transform: scale(0.95);
}

.ai-chat-new-conversation-btn {
    background: rgba(255, 255, 255, 0.2);
    border: none;
    width: 36px;
    height: 36px;
    border-radius: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background 0.2s;
    color: #ffffff;
    flex-shrink: 0;
}

.ai-chat-new-conversation-btn:hover {
    background: rgba(255, 255, 255, 0.3);
}

/* Prominent pill button – the main action in AI mode */
.ai-chat-switch-mode-btn {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 0 16px;
    height: 36px;
    background: rgba(255, 255, 255, 0.96);
    border: none;
    border-radius: 999px;
    cursor: pointer;
    color: #4f46e5;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.01em;
    white-space: nowrap;
    flex-shrink: 0;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.18);
    transition: background 0.18s ease, transform 0.15s ease, box-shadow 0.18s ease;
}

.ai-chat-switch-mode-btn:hover {
    background: #ffffff;
    transform: scale(1.04);
    box-shadow: 0 4px 18px rgba(0, 0, 0, 0.22);
}

.ai-chat-switch-mode-btn:active {
    transform: scale(0.97);
}

.ai-chat-switch-mode-btn svg {
    flex-shrink: 0;
}

.ai-conversations-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 20px;
    border-bottom: 1px solid #e9ecef;
    background: #ffffff;
}

.ai-conversations-header h3 {
    font-size: 14px;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0;
    text-transform: uppercase;
    letter-spacing: 0.5px;
}

/* Header liegt auf hellem Grund: Plus-Button violett wie Haupt-Aktion */
.ai-conversations-header .ai-chat-new-conversation-btn,
.ai-conversations-header .ai-conversations-header-new-btn {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    color: #ffffff;
    border-radius: 10px;
    width: 36px;
    height: 36px;
    border: none;
}

.ai-conversations-header .ai-chat-new-conversation-btn:hover,
.ai-conversations-header .ai-conversations-header-new-btn:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
    color: #ffffff;
}

.ai-conversations-list {
    flex: 1;
    overflow-y: auto;
}

.chat-contacts-panel #aiConversationsList.ai-conversations-list {
    flex: 1 1 0%;
    min-height: 0;
    max-height: 100%;
}

.ai-conversations-loading {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    gap: 12px;
    padding: 28px 20px 20px;
    color: #64748b;
    font-size: 14px;
    text-align: center;
    min-height: 120px;
    box-sizing: border-box;
}

.ai-conversations-loading-spinner {
    display: inline-block;
    width: 28px;
    height: 28px;
    border: 3px solid rgba(99, 102, 241, 0.25);
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: kinma-ai-conv-spin 0.75s linear infinite;
}

.ai-conversations-loading-text {
    max-width: 280px;
    line-height: 1.4;
}

@keyframes kinma-ai-conv-spin {
    to {
        transform: rotate(360deg);
    }
}

.ai-conversation-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    cursor: pointer;
    border-bottom: none;
}

.ai-conversation-item:hover {
    background: rgba(99, 102, 241, 0.08);
}

.chat-popup.ai-mode .ai-conversation-item.active {
    --kinma-ai-conversation-active-purple: #4f46e5;
    --kinma-ai-conversation-active-accent: #6366f1;
    --kinma-ai-conversation-active-text-shadow:
        0 0 6px rgba(255, 255, 255, 0.95),
        0 0 14px rgba(255, 255, 255, 0.7),
        0 1px 2px rgba(255, 255, 255, 0.9);
    background: linear-gradient(
        90deg,
        rgba(99, 102, 241, 0.72) 0%,
        rgba(99, 102, 241, 0.38) 34%,
        rgba(99, 102, 241, 0.12) 58%,
        transparent 100%
    ) !important;
    border-left: none !important;
    padding-left: 12px !important;
    box-shadow: inset 2px 0 0 var(--kinma-ai-conversation-active-accent);
}

.chat-popup.ai-mode .ai-conversation-item.active:hover {
    background: linear-gradient(
        90deg,
        rgba(99, 102, 241, 0.8) 0%,
        rgba(99, 102, 241, 0.44) 34%,
        rgba(99, 102, 241, 0.16) 58%,
        transparent 100%
    ) !important;
}

.chat-popup.ai-mode .ai-conversation-item.active .ai-conversation-info {
    overflow: visible;
}

.chat-popup.ai-mode .ai-conversation-item.active .ai-conversation-title {
    color: var(--kinma-ai-conversation-active-purple) !important;
    font-weight: 600;
    text-shadow: var(--kinma-ai-conversation-active-text-shadow);
    overflow: visible;
    padding-block: 2px;
    margin-block: -2px;
}

.chat-popup.ai-mode .ai-conversation-item.active .ai-conversation-preview {
    color: var(--kinma-ai-conversation-active-purple) !important;
    font-weight: 400;
    text-shadow: var(--kinma-ai-conversation-active-text-shadow);
    overflow: visible;
    padding-block: 2px;
    margin-block: -2px;
}

.chat-popup.ai-mode .ai-conversation-item.active .ai-conversation-time {
    color: var(--kinma-ai-conversation-active-purple) !important;
    font-size: 11px;
    font-weight: 400;
    text-shadow: none;
}

body.dark-mode .chat-popup.ai-mode .ai-conversation-item.active {
    background: linear-gradient(
        90deg,
        rgba(99, 102, 241, 0.78) 0%,
        rgba(99, 102, 241, 0.42) 34%,
        rgba(99, 102, 241, 0.14) 58%,
        transparent 100%
    ) !important;
    box-shadow: inset 2px 0 0 #6366f1;
}

body.dark-mode .chat-popup.ai-mode .ai-conversation-item.active:hover {
    background: linear-gradient(
        90deg,
        rgba(99, 102, 241, 0.86) 0%,
        rgba(99, 102, 241, 0.48) 34%,
        rgba(99, 102, 241, 0.18) 58%,
        transparent 100%
    ) !important;
}

.ai-conversation-icon {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 14px;
    flex-shrink: 0;
}

.ai-conversation-info {
    flex: 1;
    min-width: 0;
}

.ai-conversation-title {
    font-size: 14px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-bottom: 2px;
}

.ai-conversation-preview {
    font-size: 12px;
    color: #5b5f7a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.ai-conversation-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    flex-shrink: 0;
}

.ai-conversation-time {
    font-size: 11px;
    color: #7c7fa3;
}

.ai-chat-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #5b5f7a;
    text-align: center;
}
.ai-chat-empty-state .chat-empty-state-subtext {
    white-space: pre-wrap;
    max-width: min(100%, 34em);
    line-height: 1.45;
    font-size: 14px;
    margin-top: 6px;
}

.ai-chat-empty-state svg {
    color: rgba(99, 102, 241, 0.35);
    margin-bottom: 16px;
}

.ai-chat-empty-state p {
    font-size: 14px;
    margin: 0;
}

.ai-chat-input-container {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 16px;
    border-top: 1px solid #e9ecef;
    background: #ffffff;
}

.chat-popup.ai-mode .chat-popup-body {
    background: #ffffff;
}

/* KI-Modus: Haupt-Header mit Konversationstitel + Sprachanruf */
.chat-popup.ai-mode #chatMainHeader:not(.chat-main-header-call-active) {
    display: flex !important;
}

.chat-popup.ai-mode #chatMainHeader.chat-main-header-call-active {
    display: flex !important;
}

.chat-popup.ai-mode .chat-main-header-normal #chatUserInfo {
    display: none !important;
}

.chat-popup.ai-mode #aiChatHeader {
    display: flex !important;
    flex: 1;
    min-width: 0;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    cursor: default !important;
}

/* Lange Konversationstitel: nicht die ganze Kopfzeile „leer“ wirken lassen (Mitte + Telefon weit auseinander) */
.chat-popup.ai-mode #aiChatHeader .ai-chat-header-inner {
    flex: 1;
    min-width: 0;
    overflow: hidden;
}

.chat-popup.ai-mode #aiChatHeader .chat-user-details {
    min-width: 0;
    overflow: hidden;
}

.chat-popup.ai-mode #aiChatHeader .chat-user-name {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* KI-Chat: Kopfzeile im Verlauf = Violett wie Popup-Header / KI-Avatar */
.chat-popup.ai-mode #chatMainHeader.chat-main-header {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.chat-popup.ai-mode #chatMainHeader.chat-main-header:hover {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
}

.chat-popup.ai-mode #aiChatHeader .chat-user-name,
.chat-popup.ai-mode #aiChatHeader .chat-user-last-seen {
    color: rgba(255, 255, 255, 0.96);
}

.chat-popup.ai-mode #aiChatHeader .chat-user-avatar {
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

/* Sprach-Button: auf violettem Header heller Kreis statt zweitem Violett-Gradient */
.chat-popup.ai-mode #chatMainHeader .ai-voice-call-header-btn.chat-call-btn {
    background: rgba(255, 255, 255, 0.18);
    border: 1.5px solid rgba(255, 255, 255, 0.42);
    color: #ffffff;
}

.chat-popup.ai-mode #chatMainHeader .ai-voice-call-header-btn.chat-call-btn:hover {
    background: rgba(255, 255, 255, 0.28);
    box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.1);
}

.chat-popup.ai-mode #chatCallButtons,
.chat-popup.ai-mode #chatHeaderCallControls {
    display: none !important;
}

.ai-chat-header-inner {
    display: flex;
    align-items: center;
    gap: 8px;
    min-width: 0;
    flex: 1;
}

.ai-chat-header-actions {
    flex-shrink: 0;
}

.chat-popup.ai-mode .ai-voice-call-header-btn.chat-call-btn {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    color: #fff;
    cursor: pointer;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

.chat-popup.ai-mode .ai-voice-call-header-btn.chat-call-btn:hover {
    transform: scale(1.05);
    box-shadow: 0 2px 12px rgba(79, 70, 229, 0.35);
}

.ai-voice-call-session-bar {
    display: none;
    flex-direction: column;
    gap: 8px;
    padding: 10px 14px;
    background: #f1f5f9;
    border-bottom: 1px solid #e2e8f0;
    flex-shrink: 0;
}

.ai-voice-call-session-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.ai-voice-call-session-label {
    font-size: 13px;
    color: #1a1a1a;
    flex: 1;
    min-width: 140px;
}

.ai-voice-call-session-controls {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}

.ai-voice-call-ptt-btn {
    padding: 10px 16px;
    border-radius: 999px;
    border: 1px solid #cbd5e1;
    background: #fff;
    color: #1a1a1a;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    user-select: none;
    touch-action: manipulation;
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.ai-voice-call-ptt-btn:disabled {
    opacity: 0.55;
    cursor: not-allowed;
}

.ai-voice-call-ptt-btn.ai-voice-call-ptt-btn--recording {
    background: #ef4444;
    border-color: #dc2626;
    color: #fff;
}

.ai-voice-call-hangup-btn {
    padding: 10px 16px;
    border-radius: 999px;
    border: none;
    background: #64748b;
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
}

.ai-voice-call-hangup-btn:hover {
    background: #1a1a1a;
}

/* Mobile Vollbild KI: zuerst nur Unterhaltungsliste; Zurück zeigt diese Ansicht wieder */
.chat-popup.chat-popup-mobile-fullscreen.ai-mode.ai-mobile-conversation-picker #chatChatRightPanel {
    display: none !important;
}

.chat-popup.chat-popup-mobile-fullscreen.ai-mode.ai-mobile-conversation-picker #chatContactsPanel {
    flex: 1 1 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    width: 100% !important;
}

.chat-popup.chat-popup-mobile-fullscreen.ai-mode.ai-mobile-conversation-picker #chatViewSplit {
    display: flex !important;
}

/* KI ohne gewählte Unterhaltung: nur Liste (Desktop wie Familienchat ohne Kontakt — schmale Box, kein rechter Bereich) */
.chat-popup.ai-mode.ai-no-conversation-selected #chatChatRightPanel {
    display: none !important;
}

.chat-popup.ai-mode.ai-no-conversation-selected #chatViewSplit {
    display: flex !important;
}

.chat-popup.ai-mode.ai-no-conversation-selected #chatContactsPanel {
    flex: 1 1 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    width: 100% !important;
    border-right: none !important;
}

/* KI-Modus: Familien-Suche/Ordner ausblenden; KI-Suche in derselben Toolbar wie „+“ */
.chat-popup.ai-mode #chatContactsToolbar #chatSearchBackBtn,
.chat-popup.ai-mode #chatContactsToolbar #chatContactsToolbarSearchSlot,
.chat-popup.ai-mode #chatContactsToolbar #normalChatSearchContainer,
.chat-popup.ai-mode #normalChatSearchContainer {
    display: none !important;
}

.chat-popup.ai-mode #chatContactsToolbar #aiConversationsSearchContainer {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
}

.chat-popup.ai-mode #aiConversationsSearchContainer {
    display: flex !important;
}

/* Familien-Modus: KI-Suchzeile in der Toolbar ausblenden */
.chat-popup:not(.ai-mode) #chatContactsToolbar #aiConversationsSearchContainer,
.chat-popup:not(.ai-mode) #chatContactsPanel #aiConversationsSearchContainer {
    display: none !important;
}

.chat-popup.ai-mode #chatContactsPanel {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
    overflow: hidden !important;
    background: #ffffff !important;
}

/* KI-Liste Standard (z. B. Mobile): Flex-Spalte unter der Suche */
.chat-popup.ai-mode #chatContactsPanel #aiConversationsList {
    flex: 1 1 0% !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px !important;
    box-sizing: border-box !important;
}

.chat-popup.ai-mode #chatContactsPanel #chatContactAddPlaceholder {
    flex-shrink: 0 !important;
    margin: 0 !important;
    z-index: auto !important;
    box-shadow: 0 4px 18px rgba(79, 70, 229, 0.45) !important;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    background-color: #6366f1 !important;
}

/* Desktop KI: gleiche schwebende Toolbar unten wie Familien-Kontaktliste */
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) #chatContactsPanel #aiConversationsList {
    position: absolute !important;
    inset: 0 !important;
    flex: none !important;
    width: auto !important;
    max-height: none !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch;
    padding-top: 0 !important;
    padding-bottom: calc(var(--kinma-chat-contacts-toolbar-reserve, 64px) + 6px) !important;
    box-sizing: border-box !important;
}

.chat-popup.ai-mode #chatContactsPanel #chatContactAddPlaceholder:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%) !important;
    background-color: #4f46e5 !important;
}

/* AI mode: hide sidebar + divider, let chat-main fill full width */
.chat-popup.ai-mode .chat-sidebar,
.chat-popup.ai-mode .chat-divider {
    display: none !important;
}

/* KI-Modus: Split bleibt (Liste links, Verlauf rechts) — nicht volle Breite übers Kontakte-Panel */
.chat-popup.ai-mode .chat-chat-right-panel .chat-main {
    flex: 1 1 0% !important;
    min-width: 0 !important;
    width: auto !important;
    max-width: none !important;
    background: #ffffff;
}

/* Ohne andere Familien-Kontakte ist die Liste sonst ausgeblendet — für KI-Chats trotzdem linke Spalte */
.chat-popup.ai-mode:not(.chat-popup-mobile-fullscreen) .chat-popup-content-wrapper #chatViewSplit.chat-view-split-no-contacts .chat-contacts-panel {
    display: flex !important;
    flex: 0 0 280px !important;
    min-width: 240px !important;
    max-width: 360px !important;
    width: 280px !important;
    border-right: 1px solid rgba(99, 102, 241, 0.22) !important;
    background: #ffffff !important;
}

/* ── AI "Ask a question" empty state ─────────────────────────────── */
.ai-chat-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 16px;
    flex: 1;
    padding: 40px 24px;
    text-align: center;
}

/* Ripple container */
.ai-ask-voice-wrap {
    position: relative;
    width: 100px;
    height: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 8px;
}

/* Ripple rings */
.ai-ask-ripple {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    border: 2px solid rgba(99, 102, 241, 0.25);
    animation: aiAskRipple 2.4s ease-out infinite;
    pointer-events: none;
}
.ai-ask-ripple-2 { animation-delay: 0.6s; }
.ai-ask-ripple-3 { animation-delay: 1.2s; }

@keyframes aiAskRipple {
    0%   { transform: scale(0.6); opacity: 0.8; }
    100% { transform: scale(1.6); opacity: 0; }
}

/* The mic circle button */
.ai-ask-voice-btn {
    position: relative;
    z-index: 1;
    width: 72px;
    height: 72px;
    border-radius: 50%;
    border: none;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    color: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px rgba(99, 102, 241, 0.4), 0 2px 8px rgba(99, 102, 241, 0.3);
    transition: transform 0.2s cubic-bezier(0.34, 1.56, 0.64, 1),
                box-shadow 0.2s ease;
}

.ai-ask-voice-btn:hover {
    transform: scale(1.08);
    box-shadow: 0 12px 32px rgba(99, 102, 241, 0.55), 0 4px 12px rgba(99, 102, 241, 0.35);
}

.ai-ask-voice-btn:active {
    transform: scale(0.96);
}

.ai-ask-title {
    font-size: 1.1rem;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0;
    line-height: 1.3;
}

.ai-ask-subtitle {
    font-size: 0.85rem;
    color: #5b5f7a;
    margin: 0;
}
/* ─────────────────────────────────────────────────────────────────── */

.chat-popup.ai-mode .chat-messages {
    background: #ffffff;
}

.chat-popup.ai-mode .chat-message-content {
    border: none;
    outline: none;
}

/* KI-Antworten: Violett wie Akzent, helle Schrift */
.chat-popup.ai-mode .chat-message-bot .chat-message-content {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
    color: #ffffff;
    border: none;
    outline: none;
    box-shadow: none;
    hyphens: manual;
    -webkit-hyphens: manual;
    -moz-hyphens: manual;
    -ms-hyphens: manual;
    word-break: normal;
    overflow-wrap: break-word;
}

.chat-popup.ai-mode .kinma-ai-message-detail-action {
    margin-top: 6px;
    align-self: flex-start;
}

/* Button sitzt unter der blauen Blase auf weißem Verlauf — dunkle Pill, nicht „weiß auf weiß“. */
.chat-popup.ai-mode .kinma-ai-detail-expand-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 6px 14px;
    font-size: 13px;
    font-weight: 600;
    color: #3730a3;
    background: #eef2ff;
    border: 1px solid rgba(79, 70, 229, 0.45);
    border-radius: 999px;
    cursor: pointer;
    box-shadow: 0 1px 2px rgba(26, 26, 26, 0.06);
    transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.chat-popup.ai-mode .kinma-ai-detail-expand-btn:hover:not(:disabled) {
    background: #e0e7ff;
    border-color: rgba(67, 56, 202, 0.65);
    color: #312e81;
}

.chat-popup.ai-mode .kinma-ai-detail-expand-btn:disabled {
    opacity: 0.55;
    cursor: default;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text,
.chat-popup.ai-mode .chat-message-bot .chat-message-content p {
    color: #ffffff;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text a.kinma-ai-chat-link {
    color: #c7d2fe;
    text-decoration: underline;
    word-break: break-word;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text a.kinma-ai-chat-link:hover {
    color: #eef2ff;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text a.kinma-ai-chat-link--internal {
    font-weight: 600;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list {
    margin: 6px 0 6px 18px;
    padding: 0;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list ol.kinma-ai-rt-list,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list ol.kinma-ai-rt-list {
    margin-top: 4px;
    margin-bottom: 4px;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list li,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list li {
    margin: 2px 0;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-linehead {
    margin: 6px 0 2px;
    font-weight: 600;
    line-height: 1.4;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list--inline-semi {
    margin: 2px 0 8px 1.25rem;
    padding-left: 1.1rem;
    list-style-type: disc;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text code.kinma-ai-rt-code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.92em;
    background: rgba(255, 255, 255, 0.16);
    border: 1px solid rgba(255, 255, 255, 0.3);
    border-radius: 6px;
    padding: 1px 6px;
    color: #f8fafc;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap {
    margin: 8px 0;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.25);
    background: rgba(0, 0, 0, 0.15);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-lang {
    display: block;
    font-size: 0.75rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    padding: 4px 10px;
    color: rgba(248, 250, 252, 0.88);
    background: rgba(0, 0, 0, 0.2);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-pre {
    margin: 0;
    padding: 8px 10px;
    overflow-x: auto;
    font-size: 0.88em;
    line-height: 1.45;
    background: transparent;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-body {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    white-space: pre-wrap;
    word-break: break-word;
    color: #f8fafc;
    display: block;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap--rendered-md .kinma-ai-rt-fence-md {
    padding: 8px 10px;
    font-size: 0.95em;
    line-height: 1.5;
    color: #f8fafc;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap--rendered-md .kinma-ai-rt-fence-md > br:first-child:last-child {
    display: none;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h1,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h2,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h3,
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h4 {
    font-weight: 800;
    margin: 8px 0 4px;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h1 { font-size: 1.14em; }
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h2 { font-size: 1.10em; }
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h3 { font-size: 1.06em; }
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h4 { font-size: 1.03em; }

/* KaTeX (LaTeX) im KI-Chat */
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .katex {
    font-size: 1.08em;
    color: inherit;
}
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .katex-display {
    margin: 0.65em 0;
    overflow-x: auto;
    overflow-y: hidden;
    max-width: 100%;
    -webkit-overflow-scrolling: touch;
}
.chat-popup.ai-mode .chat-message-bot .chat-message-content .chat-message-text .kinma-ai-math-fallback code {
    font-size: 0.9em;
    white-space: pre-wrap;
    word-break: break-word;
}

/* KI-Chat: eigene Nachricht = helle Bubble, dunkle Schrift (invertiert zur KI) */
.chat-popup.ai-mode .chat-message-user .chat-message-content {
    background: var(--kinma-outgoing-bubble-bg, #d4cff5);
    color: #1a1a1a;
    border: none;
    outline: none;
    box-shadow: none;
}

.chat-popup.ai-mode .chat-message-user .chat-message-content .chat-message-text,
.chat-popup.ai-mode .chat-message-user .chat-message-body .chat-message-text {
    color: #1a1a1a;
}

/*
 * KI-Thread (#chatMessages im Popup): Abstände / Gruppierung wie Family.
 * Basis: #chatMessages .chat-message + .chat-message { margin-top: 0 !important } — darunter nur margin-bottom;
 * gruppierte Zeilen brauchen explizit kleinen Zwischenraum und Abstand bei neuen Gruppen (höhere Spezifität).
 */
.chat-popup.ai-mode #chatMessages .chat-message-grouped.chat-message-bot,
.chat-popup.ai-mode #chatMessages .chat-message-grouped.chat-message-user {
    margin-bottom: 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message + .chat-message.chat-message-time-cluster-start {
    margin-top: 16px !important;
}

.chat-popup.ai-mode #chatMessages > .chat-message:first-child {
    margin-top: 0 !important;
}

/* Cluster-Ecken: ai-mode Bot-Bubble ist spezifischer als .chat-message-bot.cluster-* ohne Popup */
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-only .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 6px !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 18px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-first .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-middle .chat-message-content {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last .chat-message-content {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 6px !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: 18px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-only .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 18px !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 6px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-first .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-middle .chat-message-content {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last .chat-message-content {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: 18px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 6px !important;
}

/* Pill: #chatMessages + ai-mode ist spezifischer als globale Cluster-Pill-Regeln — sonst 6px-Ecken statt 8px / volle Pill-Radien */
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-only .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 24px !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 8px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-first .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-middle .chat-message-content.chat-message-pill {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last .chat-message-content.chat-message-pill {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: 24px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 8px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-only .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 8px !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 24px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-first .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-middle .chat-message-content.chat-message-pill {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last .chat-message-content.chat-message-pill {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 8px !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: 24px !important;
}

/* KI + Family: ausgehende Antwort — feste Rundung (schlägt ai-mode Cluster oben) */
.chat-popup.ai-mode #chatMessages .chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-only .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-first .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-middle .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-last .chat-message-outgoing-stack > .chat-message-content {
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-bl: 0px !important;
    --kinma-protrude-br: 0px !important;
    /* TL TR BR BL — oben + unten Avatar-Seite (rechts) eckig, unten Mitte (links) rund */
    border-radius: 0 0 0 18px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-only .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-first .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-middle .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-last .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 0 24px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-only .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-first .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-middle .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-last .chat-message-incoming-stack > .chat-message-content {
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-bl: 0px !important;
    --kinma-protrude-br: 0px !important;
    border-radius: 0 0 18px 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-only .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-first .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-middle .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-last .chat-message-incoming-stack > .chat-message-content.chat-message-pill {
    border-radius: 0 0 24px 0 !important;
}

/* KI-Thread: Cluster ohne Schatten (wie Family-Chat) */
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-middle .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-middle .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last .chat-message-content {
    box-shadow: none;
}

.chat-popup.ai-mode .chat-message[style*="flex-direction: row-reverse"] .chat-message-content {
    background: var(--kinma-outgoing-bubble-bg, #d4cff5);
    color: #1a1a1a;
    border: none;
    outline: none;
    box-shadow: none;
}

.chat-popup.ai-mode .chat-message[style*="flex-direction: row-reverse"] .chat-message-content p {
    color: #1a1a1a;
}

.chat-popup.ai-mode .chat-message-user[style*="flex-direction: row-reverse"] .chat-message-content .chat-message-text {
    color: #1a1a1a;
}

/* Tipp-Indikator (KI) auf violetter Bubble */
.chat-popup.ai-mode .chat-message-bot .chat-message-content .ai-typing-dots span {
    background: rgba(255, 255, 255, 0.9);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .ai-typing-model-line {
    color: rgba(255, 255, 255, 0.95);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .ai-typing-progress-track {
    background: rgba(255, 255, 255, 0.32);
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.22);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .ai-typing-progress-fill {
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 0 10px rgba(255, 255, 255, 0.45);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content .ai-typing-eta {
    color: rgba(255, 255, 255, 0.88);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-reaction {
    background: rgba(255, 255, 255, 0.18);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-reaction:hover {
    background: rgba(255, 255, 255, 0.28);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-reaction-count {
    color: rgba(255, 255, 255, 0.88);
}

.chat-popup.ai-mode .chat-message-bot .chat-message-reaction-active {
    background: rgba(255, 255, 255, 0.26);
    border: 1px solid rgba(255, 255, 255, 0.42);
}

/* Fehler: muss spezifischer sein als .chat-message-bot .chat-message-content (violetter KI-Gradient) */
.chat-popup.ai-mode .chat-message-bot .chat-message-content.kinma-ai-chat-error-bubble {
    background: linear-gradient(135deg, #dc2626 0%, #b91c1c 100%) !important;
    color: #ffffff;
    border-left: none;
    box-shadow: none;
    outline: none;
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content.kinma-ai-chat-error-bubble .chat-message-text {
    color: #ffffff !important;
}

.chat-contact-item {
    display: flex;
    align-items: flex-start;
    gap: 8px;
    padding: 10px 12px;
    cursor: pointer;
    border-bottom: none;
}

/* Reorderbare Zeilen: kompakter Griff, Abstand Avatar ↔ Text unverändert */
.chat-contact-item[data-conversation-id]:has(.chat-contact-drag-handle) {
    gap: 6px;
    padding: 10px 12px 10px 3px;
    cursor: pointer;
    touch-action: none;
    -webkit-user-select: none;
    user-select: none;
}

.chat-contact-item.active:has(.chat-contact-drag-handle) {
    padding-left: 3px !important;
}

body.kinma-chat-contact-drag-active,
body.kinma-chat-contact-drag-active * {
    cursor: grabbing !important;
}

.chat-contact-item:not(.active):hover {
    background: #f1f3f5;
}

body.dark-mode .chat-contact-item:not(.active):hover {
    background: rgba(255, 255, 255, 0.06);
}

.chat-contact-item.active .chat-contact-info,
.chat-contact-item.active .chat-contact-name-wrapper {
    min-width: 0;
    overflow: visible;
}

.chat-contact-item.active {
    --kinma-chat-contact-active-grey: #1c1c1c;
    --kinma-chat-contact-active-text-shadow:
        0 0 6px rgba(255, 255, 255, 0.95),
        0 0 14px rgba(255, 255, 255, 0.7),
        0 1px 2px rgba(255, 255, 255, 0.9);
    background: linear-gradient(
        90deg,
        rgba(28, 28, 28, 0.72) 0%,
        rgba(28, 28, 28, 0.38) 34%,
        rgba(28, 28, 28, 0.12) 58%,
        transparent 100%
    ) !important;
    border-left: none !important;
    padding-left: 12px !important;
    box-shadow: inset 2px 0 0 var(--kinma-chat-contact-active-grey);
}

.chat-contact-item.active:hover {
    background: linear-gradient(
        90deg,
        rgba(28, 28, 28, 0.8) 0%,
        rgba(28, 28, 28, 0.44) 34%,
        rgba(28, 28, 28, 0.16) 58%,
        transparent 100%
    ) !important;
}

.chat-contact-item.active .chat-contact-name {
    color: var(--kinma-chat-contact-active-grey, #1c1c1c) !important;
    font-weight: 600;
    text-shadow: var(--kinma-chat-contact-active-text-shadow);
    overflow: visible;
    padding-block: 2px;
    margin-block: -2px;
}

.chat-contact-item.active .chat-contact-preview {
    color: var(--kinma-chat-contact-active-grey, #1c1c1c) !important;
    font-weight: 400;
    text-shadow: var(--kinma-chat-contact-active-text-shadow);
    overflow: visible;
    padding-block: 2px;
    margin-block: -2px;
}

.chat-contact-item.active .chat-contact-preview-call {
    color: #15803d !important;
    text-shadow: none;
}

.chat-contact-item.active .chat-contact-time {
    color: var(--kinma-chat-contact-active-grey, #1c1c1c) !important;
    font-size: 11px;
    font-weight: 400;
    text-shadow: none;
}

.chat-contact-item.active .chat-contact-drag-handle {
    color: rgba(255, 255, 255, 0.92) !important;
}

.chat-contact-item.active .chat-contact-drag-handle svg {
    color: rgba(255, 255, 255, 0.92);
    opacity: 1;
}

body.dark-mode .chat-contact-item.active {
    --kinma-chat-contact-active-grey: #1c1c1c;
    background: linear-gradient(
        90deg,
        rgba(28, 28, 28, 0.78) 0%,
        rgba(28, 28, 28, 0.42) 34%,
        rgba(28, 28, 28, 0.14) 58%,
        transparent 100%
    ) !important;
    box-shadow: inset 2px 0 0 #1c1c1c;
}

body.dark-mode .chat-contact-item.active:hover {
    background: linear-gradient(
        90deg,
        rgba(28, 28, 28, 0.86) 0%,
        rgba(28, 28, 28, 0.48) 34%,
        rgba(28, 28, 28, 0.18) 58%,
        transparent 100%
    ) !important;
}

body.dark-mode .chat-contact-item.active .chat-contact-time {
    color: #1c1c1c !important;
}

.chat-contact-item.chat-contact-item-ghost {
    opacity: 0.72;
}

.chat-contact-item.chat-contact-item-ghost .chat-contact-name,
.chat-contact-item.chat-contact-item-ghost .chat-contact-preview {
    color: #7b8594 !important;
}

/* Mobil: kein „ausgewählt“-Zustand mit blauem Balken — Chat öffnen reicht als Kontext */
@media (max-width: 768px) {
    .chat-contact-item.active {
        background: transparent !important;
        border-left: none !important;
        padding-left: 12px !important;
        font-weight: inherit !important;
    }

    .chat-contact-item.active:has(.chat-contact-drag-handle) {
        padding-left: 3px !important;
    }

    .chat-contact-item.active:hover {
        background: #f8f9fa !important;
    }
}

.chat-contact-drag-handle {
    flex-shrink: 0;
    align-self: center;
    display: flex;
    align-items: center;
    justify-content: center;
    width: auto;
    min-width: 12px;
    max-width: none;
    min-height: 28px;
    margin: 0 -3px 0 0;
    padding: 0 2px;
    box-sizing: content-box;
    cursor: inherit;
    color: #94a3b8;
    border-radius: 3px;
    touch-action: none;
    -webkit-user-select: none;
    user-select: none;
    -webkit-user-drag: none;
    user-drag: none;
}

.chat-contact-drag-handle[role='button'] {
    /* Kein Button-Fokus/Activation — gleiches Pointer-Drag wie die ganze Zeile */
    -webkit-tap-highlight-color: transparent;
}

body.kinma-chat-contact-drag-active .chat-contact-drag-handle {
    cursor: grabbing;
}

.chat-contact-drag-handle svg {
    display: block;
    width: 12px;
    height: 12px;
    flex-shrink: 0;
    pointer-events: none;
}

/* Touch: breitere Trefferfläche, gleicher optischer Abstand */
@media (max-width: 1024px) {
    .chat-contact-drag-handle {
        min-width: 14px;
        min-height: 36px;
        padding: 0 2px;
        margin-right: -3px;
    }
}

.chat-contact-item--dragging {
    display: none !important;
}

.chat-contact-drag-placeholder {
    flex-shrink: 0;
    box-sizing: border-box;
    width: 100%;
    height: 0;
    margin: 0;
    padding: 0;
    border: none;
    border-radius: 8px;
    background: rgba(99, 102, 241, 0.04);
    outline: 2px dashed rgba(99, 102, 241, 0.28);
    outline-offset: -2px;
    pointer-events: none;
    opacity: 0.35;
    overflow: hidden;
    transition:
        height 0.26s cubic-bezier(0.34, 1.14, 0.64, 1),
        opacity 0.22s ease,
        outline-color 0.22s ease,
        background-color 0.22s ease;
}

.chat-contact-drag-placeholder--open {
    opacity: 1;
    background: rgba(99, 102, 241, 0.06);
    outline-color: rgba(99, 102, 241, 0.42);
}

/* Schwebende Zeile beim Verschieben (folgt Cursor/Finger) */
.chat-contact-drag-ghost {
    position: fixed;
    z-index: 100010;
    pointer-events: none;
    box-sizing: border-box;
    margin: 0;
    opacity: 0.9;
    background: #ffffff;
    border-radius: 8px;
    box-shadow:
        0 4px 14px rgba(15, 23, 42, 0.1),
        0 0 0 1px rgba(99, 102, 241, 0.22);
    cursor: grabbing;
    transform: scale(0.985) translateY(0);
    transform-origin: center center;
    will-change: transform, left, top;
    transition:
        transform 0.26s cubic-bezier(0.34, 1.18, 0.64, 1),
        opacity 0.2s ease,
        box-shadow 0.26s ease;
}

.chat-contact-drag-ghost--lifted {
    opacity: 1;
    transform: scale(1.02) translateY(-3px);
    box-shadow:
        0 14px 36px rgba(15, 23, 42, 0.2),
        0 0 0 1px rgba(99, 102, 241, 0.38);
}

body.kinma-chat-contact-drag-active {
    cursor: grabbing !important;
    user-select: none !important;
}

body.kinma-chat-contact-drag-active .chat-contacts-list {
    scroll-behavior: auto;
}

.chat-contact-drag-ghost .chat-contact-drag-handle {
    cursor: grabbing;
}

.chat-contact-drag-ghost.active {
    border-left: none !important;
    padding-left: 3px !important;
    font-weight: inherit !important;
    background: #ffffff !important;
}

body.kinma-chat-contact-drag-active .chat-contacts-list .chat-contact-item:not(.chat-contact-item--dragging) {
    cursor: grabbing !important;
    transition: transform 0.24s cubic-bezier(0.34, 1.08, 0.64, 1);
}

@media (prefers-reduced-motion: reduce) {
    .chat-contact-drag-placeholder,
    .chat-contact-drag-ghost,
    body.kinma-chat-contact-drag-active .chat-contacts-list .chat-contact-item:not(.chat-contact-item--dragging) {
        transition: none !important;
        animation: none !important;
    }

    .chat-contact-drag-ghost--lifted {
        transform: none;
    }
}

.chat-contact-item--drag-over {
    outline: 2px dashed #6366f1;
    outline-offset: -2px;
    background: rgba(99, 102, 241, 0.06);
}

/* Zwischen zwei Zeilen: Einfügemarkierung oben/unten am Ziel */
.chat-contact-item--drag-insert-before {
    box-shadow: inset 0 3px 0 0 #6366f1;
    background: rgba(99, 102, 241, 0.045);
}

.chat-contact-item--drag-insert-after {
    box-shadow: inset 0 -3px 0 0 #6366f1;
    background: rgba(99, 102, 241, 0.045);
}

/* Pin-Badge oben links auf dem Kontakt-Avatar (wie Status-Punkt unten rechts) */
.chat-contact-avatar-wrapper .chat-contact-pin-icon.chat-contact-pin-on-avatar {
    position: absolute;
    top: -1px;
    left: -1px;
    z-index: 2;
    margin: 0;
    width: 15px;
    height: 15px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 50%;
    background: #ffffff;
    box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.98);
    color: #be185d;
    opacity: 1;
}

.chat-contact-avatar-wrapper .chat-contact-pin-on-avatar .chat-contact-pin-svg {
    display: block;
    width: 12px;
    height: 12px;
}

/* Self-Chat (Notizen): wie normale Kontakte — keine eigene Rand-/Farb-Sonderlogik */

.chat-contact-context-menu {
    background: #ffffff;
    border-radius: 20px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
    padding: 6px;
    min-width: 180px;
    z-index: 10000;
    animation: contextMenuFadeIn 0.07s ease-out;
    overflow: hidden;
}

@media (max-width: 768px) {
    .chat-contact-context-menu.chat-contact-context-menu--mobile {
        min-width: min(300px, calc(100vw - 32px));
        max-width: calc(100vw - 24px);
        box-shadow: 0 8px 28px rgba(0, 0, 0, 0.18), 0 0 0 1px rgba(0, 0, 0, 0.06);
    }

    .chat-contact-context-menu.chat-contact-context-menu--mobile .chat-context-menu-item {
        padding: 12px 14px;
        font-size: 15px;
    }
}

.chat-context-menu-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    cursor: pointer;
    border-radius: 14px;
    color: #1a1a1a;
    font-size: 14px;
    transition: background 0.15s ease;
}

.chat-context-menu-item:hover {
    background: #f8f9fa;
}

.chat-context-menu-item svg {
    flex-shrink: 0;
    color: #6c757d;
}

.chat-context-menu-item:hover svg {
    color: #1a1a1a;
}

.chat-context-menu-item-danger {
    color: #dc3545;
}

.chat-context-menu-item-danger:hover {
    background: #fee;
    color: #c82333;
}

.chat-context-menu-item-danger svg {
    color: #dc3545;
}

.chat-context-menu-item-danger:hover svg {
    color: #c82333;
}

.chat-context-menu-item-archive {
    color: #0d6efd;
}

.chat-context-menu-item-archive:hover {
    background: #e7f1ff;
    color: #0a58ca;
}

.chat-context-menu-item-archive svg {
    color: #0d6efd;
}

.chat-context-menu-item-archive:hover svg {
    color: #0a58ca;
}

.chat-context-menu-item-unarchive {
    color: #198754;
}

.chat-context-menu-item-unarchive:hover {
    background: #d1e7dd;
    color: #146c43;
}

.chat-context-menu-item-unarchive svg {
    color: #198754;
}

.chat-context-menu-item-unarchive:hover svg {
    color: #146c43;
}

.chat-context-menu-item-pin {
    color: #6366f1;
}

.chat-context-menu-item-pin:hover {
    background: #eef2ff;
    color: #4f46e5;
}

.chat-context-menu-item-pin svg {
    color: #6366f1;
}

.chat-context-menu-item-pin:hover svg {
    color: #4f46e5;
}

.chat-context-menu-item-close {
    color: #fd7e14;
}

.chat-context-menu-item-close:hover {
    background: #fff3e0;
    color: #e65100;
}

.chat-context-menu-item-close svg {
    color: #fd7e14;
}

.chat-context-menu-item-close:hover svg {
    color: #e65100;
}

.chat-context-menu-item-block {
    color: #dc3545;
}

.chat-context-menu-item-block:hover {
    background: #fee;
    color: #c82333;
}

.chat-context-menu-item-block svg {
    color: #dc3545;
}

.chat-context-menu-item-block:hover svg {
    color: #c82333;
}

.chat-context-menu-item-unblock {
    color: #198754;
}

.chat-context-menu-item-unblock:hover {
    background: #d1e7dd;
    color: #146c43;
}

.chat-context-menu-item-unblock svg {
    color: #198754;
}

.chat-context-menu-item-unblock:hover svg {
    color: #146c43;
}

.chat-context-menu-item-report {
    color: #ffc107;
}

.chat-context-menu-item-report:hover {
    background: #fff8e1;
    color: #e0a800;
}

.chat-context-menu-item-report svg {
    color: #ffc107;
}

.chat-context-menu-item-report:hover svg {
    color: #e0a800;
}

.chat-context-menu-divider {
    height: 1px;
    background: #e9ecef;
    margin: 4px 0;
}

.chat-message-context-menu {
    position: fixed;
    background: #ffffff;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
    padding: 4px;
    min-width: 180px;
    z-index: 100120;
    animation: contextMenuFadeIn 0.15s ease-out;
}

@media (max-width: 768px) {
    .chat-message-context-menu.chat-message-context-menu--mobile {
        min-width: min(320px, calc(100vw - 24px));
        max-width: calc(100vw - 24px);
        border-radius: 22px;
        box-shadow: 0 14px 40px rgba(26, 26, 26, 0.22);
        padding: 8px;
    }

    .chat-message-context-menu.chat-message-context-menu--mobile .context-menu-item {
        min-height: 50px;
        padding: 12px 14px;
        font-size: 15px;
    }
}

.chat-reply-ui {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 10px 12px;
    background: #f8f9fa;
    border-left: 3px solid #007bff;
    border-radius: 8px 8px 0 0;
    margin-bottom: 8px;
}

.chat-reply-content {
    flex: 1;
    min-width: 0;
}

.chat-reply-header {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 4px;
    font-size: 12px;
    font-weight: 600;
    color: #007bff;
}

.chat-reply-name {
    color: #007bff;
}

.chat-reply-text {
    font-size: 13px;
    color: #6c757d;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-reply-references {
    margin-top: 8px;
    padding-top: 8px;
    border-top: 1px solid #dee2e6;
    display: flex;
    flex-direction: column;
    gap: 4px;
}

.chat-reply-reference-item {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 12px;
}

.chat-reply-reference-name {
    font-weight: 600;
    color: #6c757d;
}

.chat-reply-reference-text {
    color: #868e96;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    flex: 1;
}

.chat-reply-close {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: 4px;
    cursor: pointer;
    color: #6c757d;
    transition: all 0.2s ease;
    flex-shrink: 0;
    margin-left: 8px;
}

.chat-reply-close:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

/* Kontext-Antwort: ruhig, eine Akzentkante, kein ANTWORT-Label, keine Doppel-Linie */
.chat-message-reply {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin: 0 0 6px 0;
    padding: 6px 10px;
    background: rgba(26, 26, 26, 0.045);
    border: none;
    border-radius: 8px;
    border-left: 3px solid rgba(59, 130, 246, 0.5);
    cursor: pointer;
    transition: background 0.15s ease;
    position: relative;
    font-size: 11px;
}

.chat-message-reply.has-nested-references {
    position: relative;
}

.chat-message-reply::before {
    display: none;
}

.chat-message-reply:hover {
    background: rgba(26, 26, 26, 0.075);
}

.chat-message-reply-header {
    display: flex;
    align-items: center;
    gap: 2px;
    width: 100%;
    pointer-events: auto;
    position: relative;
    z-index: 1;
}

/* Zweite vertikale Linie im Markup — ausgeblendet (Klicks auf die Zeile bleiben über den Container) */
.chat-message-reply-line {
    width: 0;
    min-width: 0;
    margin: 0;
    padding: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    flex-shrink: 0;
    align-self: stretch;
    min-height: 1em;
}

.chat-message-reply-line:hover {
    opacity: 0;
}

.chat-message-reply-content {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
    padding-left: 0;
    pointer-events: none;
}

.chat-message-reply-name {
    font-size: 11px;
    font-weight: 600;
    color: #2563eb;
    margin-bottom: 2px;
    line-height: 1.25;
}

.chat-message-reply-text {
    font-size: 11px;
    color: #64748b;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.35;
}

/* Zitat/Referenz: gleiche Avatar-Komponente wie im Verlauf, nur kleiner */
.chat-message-avatar.chat-message-inline-avatar,
.chat-message-avatar.chat-message-references-toggle-person {
    width: 24px;
    height: 24px;
    min-width: 24px;
    max-width: 24px;
    min-height: 24px;
    max-height: 24px;
    font-size: 11px;
}

.chat-message-inline-glyph {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 16px;
    height: 16px;
    min-width: 16px;
    color: #1a1a1a;
    flex: 0 0 auto;
}

.chat-message-inline-glyph svg {
    display: block;
    width: 14px;
    height: 14px;
}

.chat-message-inline-glyph--reference {
    color: #6366f1;
}

.chat-message-inline-glyph--reference svg {
    width: 13px;
    height: 13px;
}

.chat-message-inline-text {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    color: #1a1a1a;
    font-weight: 500;
}

/* Zitatblock: Überschrift außerhalb der Karten; Karten gleichmäßig gerundet, ohne seitlichen Akzentstreifen */
.chat-message-quote-stack {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    min-width: 0;
    margin: 0 0 4px 0;
    gap: 0;
    border: none;
    background: transparent;
    box-sizing: border-box;
    --chat-quote-card-max-width: 420px;
    /* Vertikale Bezugslinien: Zentrum unter Link-Icon (16px) bzw. unter Master-Toggle (padding 10px + 8px) */
    --chat-quote-thread-line-w: 2px;
    --chat-quote-thread-line: rgba(148, 163, 184, 0.58);
    --chat-quote-thread-glyph-cx: 8px;
    --chat-quote-thread-toggle-cx: calc(10px + 8px);
    /* Referenzzeile mit Index-Spalte: Linie unter Glyph (24 Nummer + gap + halbe Glyph-Breite), nur für :not(.chat-message-reference--no-index) in rekursiven Listen */
    --chat-quote-thread-nested-avatar-cx: calc(24px + 8px + 8px);
    --chat-quote-context-bg: var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98));
    --chat-quote-context-bg-hover: var(--kinma-chat-referenzen-bg-hover, rgba(245, 158, 11, 0.14));
    /* Deckend (Antwort-Box): transparentes Hover würde blauen Hintergrund durchscheinen lassen */
    --chat-quote-context-bg-hover-filled: var(--kinma-chat-referenzen-bg-hover-filled, #fde9a8);
    /* Einheitlicher Hover für Antwort- und Referenz-Zeilen im Zitat-Stack */
    --kinma-quote-interactive-hover: rgba(26, 26, 26, 0.06);
    --kinma-quote-interactive-hover-strong: rgba(26, 26, 26, 0.08);
    /* Kompakte Zeile: Antwort-Zeile und eingeklappte „X Referenzen“-Pille gleiche Höhe */
    --kinma-quote-compact-row-py: 8px;
    --kinma-quote-compact-row-px: 10px;
    --kinma-quote-compact-row-gap: 8px;
    --kinma-quote-compact-inline-size: 24px;
    --kinma-quote-compact-glyph-size: 16px;
    --kinma-quote-compact-chevron-size: 16px;
    --kinma-quote-compact-row-min-h: calc(var(--kinma-quote-compact-row-py) * 2 + var(--kinma-quote-compact-inline-size));
    --kinma-quote-collapse-duration: 0.28s;
    --kinma-quote-collapse-ease: cubic-bezier(0.4, 0, 0.2, 1);
}

/* Auf-/Zuklappen: Grid + Opacity (Scroll-Kompensation in utility-islands.js) */
.chat-message-quote-above .chat-message-references-list,
.chat-message-quote-stack .chat-message-references-list,
.chat-message-quote-above .chat-message-nested-references,
.chat-message-quote-stack .chat-message-nested-references {
    display: grid !important;
    grid-template-rows: 1fr;
    opacity: 1;
    overflow: hidden;
    transition:
        grid-template-rows var(--kinma-quote-collapse-duration) var(--kinma-quote-collapse-ease),
        opacity calc(var(--kinma-quote-collapse-duration) * 0.85) var(--kinma-quote-collapse-ease);
}

.chat-message-references-list > .chat-message-quote-collapse-inner,
.chat-message-quote-stack .chat-message-nested-references > .chat-message-nested-references-list,
.chat-message-quote-stack .chat-message-nested-references > .chat-message-quote-collapse-inner {
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.chat-message-references-list.chat-message-quote-collapse-target--collapsed,
.chat-message-quote-stack .chat-message-nested-references.chat-message-quote-collapse-target--collapsed {
    grid-template-rows: 0fr;
    opacity: 0;
    pointer-events: none;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    min-height: 0 !important;
}

/* JS height animation (kinmaAnimateCollapseHeight) — overrides grid collapse while animating */
.chat-message-references-list.kinma-collapse-panel-animating,
.chat-message-nested-references.kinma-collapse-panel-animating,
.chat-reply-references-collapse.kinma-collapse-panel-animating {
    display: block !important;
    grid-template-rows: unset !important;
    max-height: none !important;
    transition: none !important;
}

@media (prefers-reduced-motion: reduce) {
    .chat-message-quote-stack {
        --kinma-quote-collapse-duration: 0.01ms;
    }

    .chat-message-quote-above .chat-message-references-list,
    .chat-message-quote-stack .chat-message-references-list,
    .chat-message-quote-above .chat-message-nested-references,
    .chat-message-quote-stack .chat-message-nested-references,
    .chat-message-quote-stack .chat-message-references-toggle .toggle-icon,
    .chat-message-quote-stack .chat-message-reference-toggle .toggle-icon,
    .chat-message-quote-stack .chat-message-reply-toggle .toggle-icon,
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary,
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-context,
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary,
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-context {
        transition-duration: 0.01ms !important;
    }
}

.chat-message-quote-context:has(.chat-message-references-list.is-expanded),
.chat-message-quote-context:has(.chat-message-nested-references.is-expanded) {
    padding-top: 4px;
}

.chat-message-quote-stack .chat-message-references-toggle .toggle-icon,
.chat-message-quote-stack .chat-message-reference-toggle .toggle-icon,
.chat-message-quote-stack .chat-message-reply-toggle .toggle-icon {
    transition: transform var(--kinma-quote-collapse-duration) var(--kinma-quote-collapse-ease);
}

.chat-message-quote-stack .chat-message-references-toggle[data-expanded='true'] .toggle-icon,
.chat-message-quote-stack .chat-message-reference-toggle[data-expanded='true'] .toggle-icon,
.chat-message-quote-stack .chat-message-reply-toggle[data-expanded='true'] .toggle-icon {
    transform: rotate(90deg);
}

.chat-message-quote-block {
    display: flex;
    flex-direction: column;
    min-width: 0;
    width: fit-content;
    max-width: min(100%, var(--chat-quote-card-max-width));
}

.chat-message-quote-block--context {
    margin-top: 6px;
}

.chat-message-quote-stack > .chat-message-quote-block--context:first-child {
    margin-top: 0;
}

.chat-message-quote-section-label {
    margin: 0 0 1px 2px;
    padding: 0;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    line-height: 1.25;
    background: none;
    border: none;
    box-shadow: none;
    display: inline-flex;
    align-items: center;
    gap: 5px;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-section-label-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 14px;
    height: 14px;
    opacity: 0.85;
}

.chat-message-quote-section-label-icon svg {
    display: block;
    width: 12px;
    height: 12px;
}

.chat-message-quote-section-label-text {
    min-width: 0;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above .chat-message-quote-section-label {
    margin: 0 0 2px 0;
    padding: 0;
    width: 100%;
    max-width: 100%;
    justify-content: flex-end;
    box-sizing: border-box;
}

/* Ausgehend: Icon links vom Text (Profilbild ist rechts) */
.chat-message-user .chat-message-quote-section-label-icon {
    order: 0;
}

.chat-message-user .chat-message-quote-section-label-text {
    order: 1;
    text-align: right;
}

.chat-message-quote-section-label--direct {
    color: #1d4ed8;
}

.chat-message-quote-section-label--context {
    color: #64748b;
}

/* „Antwort auf“: Pfeil zeigt nach unten zum Zitat (ausgehend −90°, eingehend 90° + Spiegel) */
.chat-message-quote-section-label--direct .chat-message-quote-section-label-icon svg {
    transform-origin: center center;
}

.chat-message-user .chat-message-quote-section-label--direct .chat-message-quote-section-label-icon svg {
    transform: rotate(-90deg);
}

.chat-message-bot .chat-message-quote-section-label--direct .chat-message-quote-section-label-icon svg {
    transform: rotate(90deg) scaleX(-1);
}

/* Ausgehend: Zitat/Referenzen als eigener Block über der weißen Bubble (nicht in der Box) */
.chat-message-user .chat-message-outgoing-stack {
    display: flex;
    flex-direction: column;
    /* flex-end: keine Quer-Stretch — sonst + width:100% auf quote-above bläst den Stack auf volle Chat-Breite (Avatar wirkt „am Rand“) */
    align-items: flex-end;
    width: fit-content;
    max-width: 100%;
    align-self: flex-end;
    gap: 14px;
    min-width: 0;
}

/*
 * Ausgehend mit „Antwort auf“ (Klasse setzen JS: Family + KI): wie Familien-Chat.
 * Zeile nutzt die erlaubte Max-Breite, Inhalt (Wrapper + Avatar) wird mit flex-end rechts gebündelt —
 * verhindert, dass der Avatar am Fensterrand klebt, wenn die Zeile fälschlich die ganze Spalte breit wird.
 */
.chat-message-user.chat-message-user-has-outgoing-quote .chat-message-wrapper {
    width: fit-content;
    max-width: 100%;
    flex: 0 1 auto;
    min-width: 0;
}

.chat-message.chat-message-user.chat-message-user-has-outgoing-quote {
    display: flex;
    justify-content: flex-end;
    width: 100%;
    max-width: 88%;
    min-width: 0;
    box-sizing: border-box;
    align-self: flex-end;
}

.chat-message.chat-message-user.chat-message-user-has-outgoing-quote > .chat-message-avatar,
.chat-message.chat-message-user.chat-message-user-has-outgoing-quote > .chat-message-avatar-spacer,
.chat-message.chat-message-user.chat-message-user-has-outgoing-quote > .chat-message-avatar-column--with-delivery {
    flex-shrink: 0;
}

/* Reply/Reference threads may use more width than normal bubbles (desktop + mobile). */
.chat-message:has(.chat-message-quote-stack),
.chat-message.chat-message-user.chat-message-user-has-outgoing-quote,
.chat-message.chat-message-bot.chat-message-bot-has-incoming-quote,
.chat-message.chat-message-bot:has(.chat-message-incoming-stack) {
    max-width: 88%;
}

/* Ausgehend: Linie nur neben Antwort/Referenz; Abstand zur eigenen Bubble darunter */
.chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack,
.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) {
    /* Abstand Karten ↔ eigene Bubble; Verlauf/Linie füllen die Lücke (kein Weiß) */
    --kinma-outgoing-reply-thread-gap: 6px;
    --kinma-outgoing-reply-thread-line: var(--kinma-outgoing-bubble-bg, #d4cff5);
    gap: var(--kinma-outgoing-reply-thread-gap);
    box-sizing: border-box;
    overflow: visible;
    position: relative;
    /* DOM: Bubble vor Zitat — mit order Zitat oben, Bubble unten; Aufklappen wächst nach unten */
    flex-direction: column;
    justify-content: flex-start;
}

.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-quote-above {
    order: 1;
}

.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content {
    order: 2;
}

.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above)::before {
    content: '';
    position: absolute;
    right: 0;
    top: 2px;
    bottom: 0;
    width: 3px;
    border-radius: 999px;
    background: var(--kinma-outgoing-reply-thread-line, #d4cff5);
    box-shadow: none;
    pointer-events: none;
    z-index: 2;
}

#chatMain .chat-messages > .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-outgoing-stack:has(.chat-message-quote-above)::before,
#chatMessages > .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-outgoing-stack:has(.chat-message-quote-above)::before,
#chatMain .chat-messages > .chat-message.chat-message-user.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-outgoing-stack:has(.chat-message-quote-above)::before,
#chatMessages > .chat-message.chat-message-user.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-outgoing-stack:has(.chat-message-quote-above)::before {
    top: calc(-1 * var(--kinma-reply-cluster-chain-bridge, 0px));
}

/* Ausgehend: etwas Luft zwischen Bubble darüber und „Antwort auf“ */
#chatMain .chat-messages > .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above,
#chatMessages > .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above,
#chatMain .chat-messages > .chat-message.chat-message-user.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above,
#chatMessages > .chat-message.chat-message-user.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above {
    padding-top: var(--kinma-reply-cluster-chain-gap, 18px);
}

.chat-message-user.chat-message-cluster-last .chat-message-outgoing-stack:has(.chat-message-quote-above)::before,
.chat-message-user.chat-message-cluster-only .chat-message-outgoing-stack:has(.chat-message-quote-above)::before {
    bottom: 9px;
}

.chat-message-user.chat-message-cluster-last .chat-message-outgoing-stack:has(.chat-message-quote-above):has(> .chat-message-content.chat-message-pill)::before,
.chat-message-user.chat-message-cluster-only .chat-message-outgoing-stack:has(.chat-message-quote-above):has(> .chat-message-content.chat-message-pill)::before {
    bottom: 12px;
}

.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-quote-above {
    position: relative;
    z-index: 1;
}

.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content {
    position: relative;
    z-index: 1;
    background: var(--kinma-outgoing-bubble-bg, #d4cff5);
}

/* Quote/reply expand above the bubble: anchor scroll on the message body, not the growing quote block */
.chat-message-outgoing-stack,
.chat-message-incoming-stack {
    overflow-anchor: none;
}

.chat-message-quote-above,
.chat-message-quote-stack,
.chat-message-nested-references,
.chat-message-references-list {
    overflow-anchor: none;
}

.chat-message-outgoing-stack > .chat-message-content,
.chat-message-incoming-stack > .chat-message-content,
.chat-message-content:has(> .chat-message-quote-stack) {
    overflow-anchor: auto;
}

/* Zitat über der Bubble; Aufklappen wächst nach unten — kein Scroll-Anker auf der Bubble */
.chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    overflow-anchor: none;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-start;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 0 10px 0 0;
    margin: 0;
    border: none;
    box-sizing: border-box;
    overflow: visible;
}

/* Kein Verlauf neben dem Faden — nur die 3px-Linie (::before) */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above::after {
    content: none !important;
    display: none !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above > * {
    position: relative;
    z-index: 1;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above::before {
    content: none !important;
    display: none !important;
}

/* Segment am Bubble: ersetzt durch ::before am Stack (durchgehend) */
.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content::before {
    content: none !important;
    display: none !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack {
    margin: 0;
    border: none;
    background: transparent;
    border-radius: 0;
    overflow: visible;
    box-shadow: none;
    align-items: flex-end;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    gap: 6px;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-block {
    align-items: flex-end;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
}

/* Karten: direkte Antwort = Pill; „Weiterer Kontext“ = volle Kartenbreite mit Hintergrund */
.chat-message-quote-primary,
.chat-message-quote-context {
    position: relative;
    overflow: hidden;
    border: none;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.chat-message-quote-primary {
    width: fit-content;
    max-width: min(100%, var(--chat-quote-card-max-width));
    border-radius: var(--kinma-quote-card-r, 20px);
    box-shadow: none;
}

.chat-message-quote-context {
    width: 100%;
    max-width: min(100%, var(--chat-quote-card-max-width));
    align-self: stretch;
    border-radius: var(--kinma-quote-card-r, 20px);
    border: none;
    outline: none;
    box-shadow: none;
}

/* Referenzen-Box: keine Datums-/Zeitstempel in Kopf oder Liste */
.chat-message-quote-context .chat-message-quote-inline-time {
    display: none !important;
}

/*
 * Antwort + Referenzen: Faden-Seite flach, Außenseite + Profil unten mit --kinma-quote-card-r (20px).
 */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context {
    border-top-left-radius: var(--kinma-quote-card-r, 20px) !important;
    border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
    box-shadow: none;
    transition: border-radius var(--kinma-quote-collapse-duration) var(--kinma-quote-collapse-ease);
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
    border-top-right-radius: var(--kinma-quote-card-r, 20px) !important;
    border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
    box-shadow: none;
    transition: border-radius var(--kinma-quote-collapse-duration) var(--kinma-quote-collapse-ease);
}

/* Antwort-/Referenz-Karten: Verlauf von Profil-/Faden-Seite zur Chat-Mitte (wie Zeilen-Highlight) */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary {
    background: linear-gradient(
        to left,
        var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--kinma-chat-reply-bg, rgba(147, 197, 253, 0.92)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        var(--kinma-chat-reply-bg, rgba(147, 197, 253, 0.92)) 100%
    );
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary {
    background: linear-gradient(
        to left,
        var(--kinma-chat-reply-bg, rgba(147, 197, 253, 0.92)) 0%,
        color-mix(in srgb, var(--kinma-chat-reply-bg, rgba(147, 197, 253, 0.92)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
            var(--kinma-chat-wall-gradient-mid, 42%),
        var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade, 72%)
    );
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-context {
    background: linear-gradient(
        to left,
        var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 100%
    );
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-context {
    background: linear-gradient(
        to left,
        var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 0%,
        color-mix(in srgb, var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
            var(--kinma-chat-wall-gradient-mid, 42%),
        var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade, 72%)
    );
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-context,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-context {
    box-shadow: none;
}

/* Aufgeklappt: kein overflow-clip — vermeidet abgeschnittene Fäden/Linien und harte Kanten an den Rundungen */
.chat-message-quote-context:has(.chat-message-references-list.is-expanded),
.chat-message-quote-context:has(.chat-message-nested-references.is-expanded),
.chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
.chat-message-quote-primary:has(.chat-message-nested-references.is-expanded) {
    overflow: visible;
}

/* Aufgeklappt: Inhalt oben statt am unteren Rand — vermeidet leeren Gradient-Bereich ohne Text */
.chat-message-quote-context:has(.chat-message-references-list.is-expanded),
.chat-message-quote-context:has(.chat-message-nested-references.is-expanded),
.chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
.chat-message-quote-primary:has(.chat-message-nested-references.is-expanded),
.chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) {
    justify-content: flex-start;
}

.chat-message-quote-context:has(.chat-message-references-list.is-expanded) .chat-message-quote-context-body,
.chat-message-quote-context:has(.chat-message-nested-references.is-expanded) .chat-message-quote-context-body,
.chat-message-quote-primary:has(.chat-message-references-list.is-expanded) .chat-message-quote-primary-body,
.chat-message-quote-primary:has(.chat-message-nested-references.is-expanded) .chat-message-quote-primary-body,
.chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded)
    .chat-message-quote-primary-body {
    justify-content: flex-start;
}

.chat-message-quote-stack
    .chat-message-references--in-quote-stack
    > .chat-message-references-list.is-expanded
    > .chat-message-quote-collapse-inner,
.chat-message-quote-above
    .chat-message-references--in-quote-stack
    > .chat-message-references-list.is-expanded
    > .chat-message-quote-collapse-inner,
.chat-message-quote-stack .chat-message-nested-references.is-expanded > .chat-message-quote-collapse-inner,
.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded > .chat-message-quote-collapse-inner,
.chat-message-quote-nested--reply-target-refs .chat-message-references-list.is-expanded > .chat-message-quote-collapse-inner {
    justify-content: flex-start;
}

.chat-message-quote-nested--reply-target-refs:has(> .chat-message-nested-references.is-expanded) {
    justify-content: flex-start;
    margin-top: 0;
}

/*
 * Aufgeklappt: Faden-Seite oben 16px + unten 20px; Profil-Seite oben 0, unten 20px.
 */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded),
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded),
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context:has(.chat-message-nested-references.is-expanded) {
    border-top-left-radius: var(--kinma-quote-card-r-expanded, 16px) !important;
    border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded),
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded),
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context:has(.chat-message-nested-references.is-expanded) {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
    border-top-right-radius: var(--kinma-quote-card-r-expanded, 16px) !important;
    border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
}

/* Innere Referenz-Fläche erbt die Karte — keine zweite Pill-Rundung */
.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded) .chat-message-references.chat-message-references--in-quote-stack,
.chat-message-quote-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded) .chat-message-references--in-quote-stack {
    border-radius: 0 !important;
}

/* Aufgeklappt: untere Listenzeile — Faden-Ecke wie Kartenradius (Toggle oben, Liste unten) */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded)
    .chat-message-references-list .chat-message-reference:last-child,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded)
    .chat-message-nested-references-list .chat-message-reference:last-child,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs
    .chat-message-references-list .chat-message-reference:last-child {
    border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded)
    .chat-message-references-list .chat-message-reference:last-child,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded)
    .chat-message-nested-references-list .chat-message-reference:last-child,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs
    .chat-message-references-list .chat-message-reference:last-child {
    border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
}

/*
 * Pro Referenz-Gruppierung: nur wenn diese konkrete Liste aufgeklappt ist, „kartenrund“ statt voller Pill —
 * gilt rekursiv für Gruppierungen innerhalb von Gruppierungen (jeweils eigener .chat-message-references-Block).
 */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary-body > .chat-message-reply:first-child {
    border-radius: 0;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary .chat-message-quote-nested {
    border-top: 1px solid rgba(26, 26, 26, 0.08);
}

.chat-message-quote-primary-body {
    min-width: 0;
    width: fit-content;
    max-width: 100%;
    overflow-x: clip;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.chat-message-quote-context-body {
    min-width: 0;
    width: 100%;
    max-width: 100%;
    overflow-x: clip;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
}

/* Master-Toggle: Toggle oben, Liste darunter (wie Composer-Reply) */
.chat-message-quote-stack .chat-message-references--in-quote-stack.chat-message-references--multi-collapse,
.chat-message-quote-above .chat-message-references--in-quote-stack.chat-message-references--multi-collapse {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    width: 100%;
    min-width: 0;
    gap: 0;
}

/* Kontext-Block: von oben nach unten wachsen */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above > .chat-message-quote-stack,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above > .chat-message-quote-stack {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-end;
    width: 100%;
    min-width: 0;
}

.chat-message-your-reply-indicator {
    padding: 10px 14px 8px;
    margin: 0;
    box-sizing: border-box;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-your-reply-indicator {
    background: linear-gradient(180deg, rgba(239, 246, 255, 0.55) 0%, rgba(255, 255, 255, 0) 100%);
    border-bottom: 1px solid rgba(59, 130, 246, 0.1);
}

.chat-message-your-reply-indicator-text {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.07em;
    text-transform: uppercase;
    color: #1e40af;
    line-height: 1.2;
    white-space: nowrap;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-your-reply-indicator-text::before {
    content: '';
    width: 7px;
    height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
    background: #3b82f6;
    box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.22);
}

.chat-message-quote-stack .chat-message-reference-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    min-width: 24px;
    height: 24px;
    margin-top: 1px;
    border-radius: 7px;
    font-size: 11px;
    font-weight: 700;
    font-variant-numeric: tabular-nums;
    color: #1a1a1a;
    background: rgba(26, 26, 26, 0.06);
    border: 1px solid rgba(26, 26, 26, 0.08);
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-reference {
    border: none !important;
    border-left: none !important;
    outline: none;
}

/* „Weiterer Kontext“: keine Index-Zahlen vor den Zeilen */
.chat-message-quote-stack .chat-message-reference--no-index .chat-message-reference-header {
    gap: var(--kinma-quote-compact-row-gap);
    align-items: center;
}

.chat-message-quote-stack .chat-message-quote-context-body .chat-message-reference-header {
    gap: var(--kinma-quote-compact-row-gap);
    align-items: center;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context .chat-message-references--in-quote-stack {
    border-top: none;
    margin-top: 0;
}

/* Eigene Antwort-Bubble (helles Lila): unterhalb der Linie — feste „Reply“-Form (unabhängig von Cluster/Protrusion) */
.chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content {
    border-top: none;
    margin-top: 0;
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-bl: 0px !important;
    --kinma-protrude-br: 0px !important;
    border-radius: 0 0 0 18px !important;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
    align-self: flex-end;
}

.chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 0 24px !important;
}

/*
 * Eingehend mit „Antwort auf“: Spiegelung der ausgehenden Reply-Sammlung (Linie links, feste Rundungen).
 */
.chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-wrapper {
    width: fit-content;
    max-width: 100%;
    flex: 0 1 auto;
    min-width: 0;
}

.chat-message.chat-message-bot.chat-message-bot-has-incoming-quote {
    display: flex;
    justify-content: flex-start;
    width: 100%;
    max-width: 88%;
    min-width: 0;
    box-sizing: border-box;
    align-self: flex-start;
}

.chat-message.chat-message-bot.chat-message-bot-has-incoming-quote > .chat-message-avatar,
.chat-message.chat-message-bot.chat-message-bot-has-incoming-quote > .chat-message-avatar-spacer,
.chat-message.chat-message-bot.chat-message-bot-has-incoming-quote > .chat-message-avatar-column--with-delivery {
    flex-shrink: 0;
}

.chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack,
.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) {
    --kinma-incoming-reply-thread-gap: 6px;
    --kinma-incoming-reply-thread-line: var(--kinma-incoming-bubble-bg, #212121);
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: fit-content;
    max-width: 100%;
    align-self: flex-start;
    gap: var(--kinma-incoming-reply-thread-gap);
    min-width: 0;
    box-sizing: border-box;
    overflow: visible;
    position: relative;
}

.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-quote-above {
    order: 1;
}

.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    order: 2;
}

/* Durchgehender Faden: ein Strich über Zitat + Lücke + Bubble (kein „Gap“ in der Mitte) */
.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above)::before {
    content: '';
    position: absolute;
    left: 0;
    top: 2px;
    bottom: 0;
    width: 3px;
    border-radius: 999px;
    background: var(--kinma-incoming-reply-thread-line, #212121);
    box-shadow: none;
    pointer-events: none;
    z-index: 2;
}

/*
 * Zwei Reply-Zeilen direkt hintereinander (≤5-Min-Cluster): ohne Anhebung endet der Faden der unteren Zeile
 * unterhalb der oberen (flex-end + Zeilenhöhe). Negatives top überbrückt die Lücke.
 */
#chatMain .chat-messages > .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-incoming-stack:has(.chat-message-quote-above)::before,
#chatMessages > .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-incoming-stack:has(.chat-message-quote-above)::before,
#chatMain .chat-messages > .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-incoming-stack:has(.chat-message-quote-above)::before,
#chatMessages > .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-incoming-stack:has(.chat-message-quote-above)::before {
    top: calc(-1 * var(--kinma-reply-cluster-chain-bridge, 0px));
}

/* Eingehend: etwas Luft zwischen Bubble darüber und „Antwort auf“ */
#chatMain .chat-messages > .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above,
#chatMessages > .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above,
#chatMain .chat-messages > .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above,
#chatMessages > .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break)
    .chat-message-quote-above {
    padding-top: var(--kinma-reply-cluster-chain-gap, 18px);
}

/* Letzte / einzige Nachricht im Cluster: Faden endet über der unteren linken Rundung der Bubble */
.chat-message-bot.chat-message-cluster-last .chat-message-incoming-stack:has(.chat-message-quote-above)::before,
.chat-message-bot.chat-message-cluster-only .chat-message-incoming-stack:has(.chat-message-quote-above)::before {
    bottom: 9px;
}

.chat-message-bot.chat-message-cluster-last .chat-message-incoming-stack:has(.chat-message-quote-above):has(> .chat-message-content.chat-message-pill)::before,
.chat-message-bot.chat-message-cluster-only .chat-message-incoming-stack:has(.chat-message-quote-above):has(> .chat-message-content.chat-message-pill)::before {
    bottom: 12px;
}

.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-quote-above {
    position: relative;
    z-index: 1;
}

.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    position: relative;
    z-index: 1;
    background: var(--kinma-incoming-bubble-bg, #212121);
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 0 0 0 10px;
    margin: 0;
    border: none;
    box-sizing: border-box;
    overflow: visible;
}

/* Kein Verlauf neben dem Faden — nur die 3px-Linie (::before) */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above::after {
    content: none !important;
    display: none !important;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above > * {
    position: relative;
    z-index: 1;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above::before {
    content: none !important;
    display: none !important;
}

.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content::before {
    content: none !important;
    display: none !important;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack {
    margin: 0;
    border: none;
    background: transparent;
    border-radius: 0;
    overflow: visible;
    box-shadow: none;
    align-items: flex-start;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    gap: 6px;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-block {
    align-items: flex-start;
    align-self: stretch;
    width: 100%;
    max-width: 100%;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context {
    border: none;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary-body > .chat-message-reply:first-child {
    border-radius: 0;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary .chat-message-quote-nested {
    border-top: 1px solid rgba(26, 26, 26, 0.08);
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above .chat-message-quote-section-label {
    margin: 0 0 2px 0;
    padding: 0;
    width: 100%;
    max-width: 100%;
    justify-content: flex-start;
    box-sizing: border-box;
}

/* Eingehend: Icon rechts vom Text (Profilbild ist links) */
.chat-message-bot .chat-message-quote-section-label-text {
    order: 0;
    text-align: left;
}

.chat-message-bot .chat-message-quote-section-label-icon {
    order: 1;
}

/* Reply-Zeile im Zitat: kein Pfeil-Icon neben dem Avatar */
.chat-message-quote-stack .chat-message-reply-content > .chat-message-inline-glyph {
    display: none !important;
}

/* Eingehende Antwort-Bubble: oben Mitte + unten Avatar-Seite (links) eckig, unten Mitte rund */
.chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    border-top: none;
    margin-top: 0;
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-bl: 0px !important;
    --kinma-protrude-br: 0px !important;
    border-radius: 0 0 18px 0 !important;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
    align-self: flex-start;
}

.chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 24px 0 !important;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context .chat-message-references--in-quote-stack {
    border-top: none;
    margin-top: 0;
}

/* Eingehend: gleiche Karten/Labels wie ausgehend */
.chat-message-bot .chat-message-quote-block--context {
    margin-top: 6px;
}

.chat-message-bot .chat-message-quote-stack > .chat-message-quote-block--context:first-child {
    margin-top: 0;
}

/* Eingehend: Quote oben ohne große Außen-Bubble; Nachrichtenkörper unter dem Quote = gleiche helle Bubble wie ausgehend */
.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) {
    position: static;
    padding: 0;
    box-sizing: border-box;
    background: transparent;
    box-shadow: none;
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack)::before {
    display: none;
}

/* Eingehend: kein zusätzlicher Trenner unter dem Quote-Stack */
.chat-message-bot .chat-message-content > .chat-message-quote-stack {
    margin-bottom: 0;
    padding-bottom: 0;
    border-bottom: none;
    align-self: flex-start;
}

/* Nachrichtenteil unter Zitat: gleiche dunkle Eingangs-Blase */
.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-attachments,
.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-poll,
.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-text,
.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-reactions {
    background: var(--kinma-incoming-bubble-bg, #212121);
    color: #ffffff;
    border-radius: 0 0 18px 0;
    padding: 10px 14px 10px 10px;
    box-shadow: none;
    align-self: flex-start;
    max-width: 100%;
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-text {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-attachments {
    padding: 8px 10px;
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-reactions {
    padding: 6px 10px;
}

.chat-message-content:has(> .chat-message-quote-stack) {
    gap: 12px;
}


/* .chat-message-reply liegt nach Split oft in .chat-message-quote-primary */
.chat-message-quote-row {
    display: flex;
    align-items: center;
    gap: 8px;
    width: fit-content;
    max-width: 100%;
}

.chat-message-quote-stack .chat-message-quote-row {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-inline-time {
    flex-shrink: 0;
    font-size: 11px;
    line-height: 1.2;
    color: rgba(26, 26, 26, 0.62);
    white-space: nowrap;
    font-variant-numeric: tabular-nums;
}

.chat-message-quote-stack .chat-message-reply {
    margin: 0;
    padding: var(--kinma-quote-compact-row-py) var(--kinma-quote-compact-row-px);
    min-height: var(--kinma-quote-compact-row-min-h);
    box-sizing: border-box;
    border-radius: 0;
    border: none;
    border-left: none;
    background: transparent;
    box-shadow: none;
    width: fit-content;
    max-width: 100%;
}

.chat-message-quote-stack .chat-message-reply:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
}

.chat-message-quote-stack .chat-message-reply-header {
    display: flex;
    align-items: center;
    gap: var(--kinma-quote-compact-row-gap);
    width: 100%;
    max-width: 100%;
    min-width: 0;
    min-height: var(--kinma-quote-compact-inline-size);
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-reply-header > .chat-message-reply-content {
    flex: 0 1 auto;
    min-width: 0;
    max-width: calc(100% - var(--kinma-quote-reply-toggle-zone-min, 48px));
}

/* Chevron-Zone: Klickfläche bis zum Kartenrand, ohne die Zeilenhöhe zu vergrößern */
.chat-message-quote-stack .chat-message-reply.has-nested-references {
    padding-right: 0;
}

.chat-message-quote-stack .chat-message-reply.has-nested-references .chat-message-reply-header {
    align-items: stretch;
    width: 100%;
    min-height: var(--kinma-quote-compact-inline-size);
}

.chat-message-quote-stack .chat-message-reply.has-nested-references .chat-message-reply-header > .chat-message-reply-toggle {
    flex: 1 1 0;
    min-width: var(--kinma-quote-reply-toggle-zone-min, 48px);
    width: auto;
    height: auto;
    min-height: 0;
    margin: calc(-1 * var(--kinma-quote-compact-row-py)) calc(-1 * var(--kinma-quote-compact-row-px)) calc(-1 * var(--kinma-quote-compact-row-py)) 0;
    padding: 0 var(--kinma-quote-compact-row-px);
    align-self: stretch;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    border: none;
    background: transparent;
    border-radius: 0;
    cursor: pointer;
    display: flex;
    flex-shrink: 1;
}

/* Gleiches Chevron wie „X Referenzen“ (›), zentriert in der Klickfläche */
.chat-message-quote-stack .chat-message-reply.has-nested-references .chat-message-reply-header > .chat-message-reply-toggle .toggle-icon {
    width: var(--kinma-quote-compact-chevron-size);
    height: var(--kinma-quote-compact-chevron-size);
    min-width: var(--kinma-quote-compact-chevron-size);
    min-height: var(--kinma-quote-compact-chevron-size);
    flex-shrink: 0;
    color: #1a1a1a;
    opacity: 1;
    transform: rotate(0deg);
    transform-origin: center center;
}

.chat-message-quote-stack .chat-message-reply.has-nested-references .chat-message-reply-header > .chat-message-reply-toggle:hover,
.chat-message-quote-stack .chat-message-reply.has-nested-references .chat-message-reply-header > .chat-message-reply-toggle:focus-visible {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
}

.chat-message-quote-stack .chat-message-reply-content {
    flex: 1;
    min-width: 0;
    pointer-events: none;
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: var(--kinma-quote-compact-row-gap);
    min-height: var(--kinma-quote-compact-inline-size);
    direction: ltr;
}

.chat-message-quote-stack .chat-message-reply-content .chat-message-quote-identity {
    flex: 1 1 auto;
    min-width: 0;
}

.chat-message-quote-stack .chat-message-quote-identity {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: flex-start;
    gap: var(--kinma-quote-compact-row-gap, 8px);
    min-width: 0;
    flex: 1 1 auto;
    direction: ltr;
}

/* Avatar links, Name/Text rechts (gilt auch wenn älteres Markup ohne Wrapper gerendert wurde) */
.chat-message-quote-stack .chat-message-quote-identity > .chat-message-avatar.chat-message-inline-avatar,
.chat-message-quote-stack .chat-message-reference-content > .chat-message-avatar.chat-message-inline-avatar {
    order: 0;
    flex: 0 0 auto;
}

.chat-message-quote-stack .chat-message-quote-identity > .chat-message-inline-text,
.chat-message-quote-stack .chat-message-quote-identity > .chat-message-reply-text,
.chat-message-quote-stack .chat-message-quote-identity > .chat-message-reference-text,
.chat-message-quote-stack .chat-message-reference-content > .chat-message-reference-text,
.chat-message-quote-stack .chat-message-reference-content > .chat-message-inline-text {
    order: 1;
    flex: 1 1 auto;
    min-width: 0;
}

.chat-message-quote-stack .chat-message-quote-identity .chat-message-quote-inline-body,
.chat-message-quote-stack .chat-message-references-toggle-label .chat-message-quote-inline-body {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    gap: 0;
    min-width: 0;
    flex: 1 1 auto;
    max-width: 100%;
    overflow: hidden;
}

.chat-message-quote-stack .chat-message-quote-identity .chat-message-quote-inline-name,
.chat-message-quote-stack .chat-message-references-toggle-label .chat-message-quote-inline-name {
    display: block;
    width: 100%;
    max-width: 100%;
    font-weight: 700;
    font-size: 10px;
    line-height: 1.15;
    color: #1a1a1a;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-message-quote-stack .chat-message-quote-identity .chat-message-quote-inline-preview,
.chat-message-quote-stack .chat-message-references-toggle-label .chat-message-quote-inline-preview {
    display: block;
    width: 100%;
    max-width: 100%;
    font-size: 11px;
    line-height: 1.15;
    font-weight: 500;
    color: #1a1a1a;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Group summary row (“3 Referenzen”): no sender name, single-line label */
.chat-message-quote-stack .chat-message-references-toggle-label .chat-message-quote-inline-body:not(:has(.chat-message-quote-inline-name)) {
    justify-content: center;
}

.chat-message-quote-stack .chat-message-references-toggle-label .chat-message-quote-inline-body:not(:has(.chat-message-quote-inline-name)) .chat-message-quote-inline-preview {
    font-size: 12px;
    line-height: 1.25;
}

.chat-message-quote-stack .chat-message-reference-content .chat-message-quote-identity {
    flex: 1 1 auto;
    min-width: 0;
}

.chat-message-quote-stack .chat-message-inline-glyph--reference {
    display: none !important;
}

.chat-message-quote-stack .chat-message-quote-identity .chat-message-inline-avatar {
    flex-shrink: 0;
}

.chat-message-quote-stack .chat-message-quote-identity .chat-message-inline-text {
    min-width: 0;
}

.chat-message-quote-primary .chat-message-quote-inline-time,
.chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-row > .chat-message-quote-inline-time {
    display: none !important;
}

.chat-message-quote-stack .chat-message-reply-name,
.chat-message-quote-stack .chat-message-reference-name {
    font-size: 12px;
    display: none;
}

.chat-message-quote-stack .chat-message-quote-sender-name {
    display: none !important;
}

/* Zitat-Avatar: Bild mit Initialen-Fallback bei Ladefehler */
.chat-message-avatar.chat-message-inline-avatar,
.chat-message-avatar.chat-message-references-toggle-person {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.chat-message-avatar--has-img .chat-message-avatar-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
    z-index: 1;
}

.chat-message-avatar--has-img .chat-message-avatar-initials {
    position: relative;
    z-index: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    font-size: inherit;
    line-height: 1;
}

.chat-message-avatar--has-img .chat-message-avatar-initials .chat-group-avatar-icon {
    width: 14px;
    height: 14px;
}

.chat-message-avatar--has-img:has(.chat-message-avatar-img) .chat-message-avatar-initials {
    opacity: 0;
    pointer-events: none;
}

.chat-message-quote-stack .chat-message-reply-text,
.chat-message-quote-stack .chat-message-reference-text {
    display: block;
    min-width: 0;
    overflow: hidden;
    white-space: normal;
    word-break: normal;
}

/*
 * Antwort-Zeile (blaue Karte): min. Breite + 2-Zeilen-Clamp.
 * Ohne min-width kollabiert fit-content + flex (min-width:0) → ein Buchstabe pro Zeile.
 */
.chat-message-quote-stack .chat-message-quote-block--primary .chat-message-quote-primary,
.chat-message-quote-stack .chat-message-quote-block--context .chat-message-quote-context {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-primary {
    min-width: min(11rem, 100%);
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-reply-header > .chat-message-reply-content {
    flex: 1 1 auto;
    min-width: 0;
    max-width: 100%;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-reply-text,
.chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-identity > .chat-message-inline-text {
    display: block;
    min-width: 0;
    overflow: hidden;
    white-space: normal;
}

/* Zitat über der Bubble: Stack/Blöcke volle verfügbare Breite (sonst fit-content → Säulentext) */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-above > .chat-message-quote-stack,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-above > .chat-message-quote-stack {
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-message-quote-stack > .chat-message-quote-block--primary,
.chat-message-quote-stack > .chat-message-quote-block--context {
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-message-quote-stack > .chat-message-quote-block--primary .chat-message-quote-section-label,
.chat-message-quote-stack > .chat-message-quote-block--context .chat-message-quote-section-label {
    width: 100%;
    max-width: 100%;
    margin-bottom: 2px;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-reference-spacer,
.chat-message-quote-stack .chat-message-reply-line,
.chat-message-quote-stack .chat-message-reference-line {
    display: none !important;
}

.chat-message-quote-nested {
    width: 100%;
    min-width: 0;
    border-top: 1px solid rgba(26, 26, 26, 0.08);
    background: rgba(255, 255, 255, 0.45);
}

/* Keine zweite Kartenfläche im Zitat-Stack — nur die äußere quote-context / quote-primary */
.chat-message-quote-stack .chat-message-quote-nested {
    background: transparent;
}

.chat-message-quote-stack .chat-message-nested-references {
    margin: 0;
    padding: 6px 10px 8px;
    border: none;
    border-left: none;
    width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-nested-references.is-expanded {
    pointer-events: auto;
}

/* Unter jedem Gruppierungs-Icon (Referenzzeile mit Kindern): senkrechte Linie exakt unter dem Glyph-Zentrum */
.chat-message-quote-stack .chat-message-reference--no-index > .chat-message-nested-references {
    --chat-thread-cx: var(--chat-quote-thread-glyph-cx);
    position: relative;
    margin-top: 6px;
    margin-left: 0;
    padding-top: 4px;
    padding-right: 0;
    padding-bottom: 8px;
    padding-left: calc(var(--chat-thread-cx) + 14px);
}

.chat-message-quote-stack .chat-message-reference:not(.chat-message-reference--no-index) > .chat-message-nested-references {
    --chat-thread-cx: calc(24px + 8px + 8px);
    position: relative;
    margin-top: 6px;
    margin-left: 0;
    padding-top: 4px;
    padding-right: 0;
    padding-bottom: 8px;
    padding-left: calc(var(--chat-thread-cx) + 14px);
}

.chat-message-quote-stack .chat-message-quote-context-body .chat-message-reference:not(.chat-message-reference--no-index) > .chat-message-nested-references {
    --chat-thread-cx: calc(24px + 10px + 8px);
}

/*
 * Rekursive Liste: nummerierte Zeile (ohne --no-index) — Achse unter Referenz-Glyph der Elternzeile.
 * Zeilen mit .chat-message-reference--no-index nutzen .chat-message-reference--no-index > .chat-message-nested-references (Glyph-Mitte).
 */
.chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference:not(.chat-message-reference--no-index) > .chat-message-nested-references,
.chat-message-quote-stack .chat-message-quote-context-body .chat-message-nested-references-list .chat-message-reference:not(.chat-message-reference--no-index) > .chat-message-nested-references {
    --chat-thread-cx: var(--chat-quote-thread-nested-avatar-cx);
    padding-left: calc(var(--chat-thread-cx) + 14px);
}

.chat-message-quote-stack .chat-message-reference > .chat-message-nested-references::before {
    content: '';
    display: block !important;
    position: absolute;
    left: var(--chat-thread-cx, var(--chat-quote-thread-glyph-cx));
    transform: translateX(-50%);
    top: 0;
    bottom: 0;
    width: var(--chat-quote-thread-line-w);
    border-radius: 999px;
    background: var(--chat-quote-thread-line);
    pointer-events: none;
    z-index: 0;
}

.chat-message-quote-stack .chat-message-reference > .chat-message-nested-references > * {
    position: relative;
    z-index: 1;
}

.chat-message-quote-stack .chat-message-nested-references-list {
    display: flex;
    flex-direction: column;
    gap: 6px;
    width: 100%;
    margin: 0;
    padding: 0;
}

.chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference {
    margin-left: 0;
    background: transparent;
    border: none;
    outline: none;
    padding: 8px 14px;
    box-shadow: none;
}

.chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference:hover {
    background: rgba(26, 26, 26, 0.06);
}

.chat-message-quote-stack .chat-message-nested-references .chat-message-nested-references {
    margin-left: 0;
    margin-top: 2px;
    padding: 2px 0 6px;
    border-left: none;
}

/* Gruppierung in Gruppierung (beliebig tief unter .nested-references): kein zweiter Kasten / keine Trennlinie */
.chat-message-quote-stack .chat-message-nested-references .chat-message-references.chat-message-references--in-quote-stack {
    border-top: none;
    margin-top: 0;
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
    background: transparent;
}

/* Antwort-Box: Hintergrund auf dem aufklappbaren .nested-references — innere Gruppierung ohne zweite Fläche */
.chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references.chat-message-references--in-quote-stack {
    background: transparent !important;
    margin: 0 !important;
    padding: 0 !important;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    border: none !important;
    overflow: hidden;
}

.chat-message-quote-stack .chat-message-nested-references .chat-message-references.chat-message-references--in-quote-stack:has(.chat-message-references-list.is-expanded) {
    padding-bottom: 6px;
}

.chat-message-quote-stack .chat-message-references--in-quote-stack {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 0;
    margin-top: 0;
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
    border: none;
    outline: none;
    position: relative;
    width: auto;
    max-width: 100%;
    align-self: flex-start;
    box-sizing: border-box;
    background: transparent;
}

/* „Weiterer Kontext“: Referenzzeilen über volle Kartenbreite (nicht nur Textbreite) */
.chat-message-quote-context .chat-message-references--in-quote-stack,
.chat-message-quote-context-body > .chat-message-references--in-quote-stack {
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    align-items: stretch;
}

.chat-message-quote-context-body .chat-message-quote-row {
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    box-sizing: border-box;
}

.chat-message-quote-context-body .chat-message-reference {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* Aufklappen: Toggle oben, Liste darunter */
.chat-message-quote-stack .chat-message-reference.has-nested-references {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
}

.chat-message-quote-nested--reply-target-refs {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: stretch;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    margin-top: 0;
}

.chat-message-quote-stack .chat-message-references--in-quote-stack:has(.chat-message-references-list.is-expanded) {
    padding-bottom: 6px;
}

.chat-message-quote-stack > .chat-message-references--in-quote-stack:first-child {
    border-top: none;
}

/* Kontext-Karte trägt den Hintergrund — innerer Block ohne zweite Fläche */
.chat-message-quote-context-body > .chat-message-references--in-quote-stack {
    border-top: none;
    background: transparent;
}

.chat-message-quote-stack .chat-message-references-list {
    width: 100%;
    gap: 6px;
}

.chat-message-quote-stack .chat-message-references--in-quote-stack > .chat-message-references-list.is-expanded {
    padding-top: 0;
    margin-top: 2px;
}

/* Master-Gruppierung („X Referenzen“): Linie unter dem Toggle-Glyph bis zur Liste */
.chat-message-quote-stack .chat-message-references--in-quote-stack > .chat-message-references-list.is-expanded {
    position: relative;
    padding-left: calc(var(--chat-quote-thread-toggle-cx) + 14px);
}

.chat-message-quote-stack .chat-message-references--in-quote-stack > .chat-message-references-list.is-expanded::before {
    content: '';
    display: block !important;
    position: absolute;
    left: var(--chat-quote-thread-toggle-cx);
    transform: translateX(-50%);
    top: 0;
    bottom: 0;
    width: var(--chat-quote-thread-line-w);
    border-radius: 999px;
    background: var(--chat-quote-thread-line);
    pointer-events: none;
    z-index: 0;
}

.chat-message-quote-stack .chat-message-references--in-quote-stack > .chat-message-references-list.is-expanded > .chat-message-quote-collapse-inner > * {
    position: relative;
    z-index: 1;
}

.chat-message-quote-stack .chat-message-references-list .chat-message-reference {
    margin-left: 0;
    border: none;
    outline: none;
    background: transparent;
    padding: 8px 14px;
    box-shadow: none;
}

.chat-message-quote-context-body .chat-message-references-list .chat-message-reference {
    background: transparent;
    border: none;
    outline: none;
    margin-top: 4px;
}

/* Listenzeilen: flach an der Faden-Seite, Pill zur Außenseite (wie Antwort-/Referenz-Karte) */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-references-list .chat-message-reference,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-top-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-references-list .chat-message-reference,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference {
    border-top-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
}

.chat-message-quote-context-body .chat-message-references-list .chat-message-reference:first-child {
    margin-top: 0;
}

.chat-message-quote-context-body .chat-message-references-list .chat-message-reference:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
}

/* Unterreferenzen in „Weiterer Kontext“: in der gelben Karte bleiben, nicht wie Antwort-Box (blau) */
.chat-message-quote-context .chat-message-nested-references.is-expanded,
.chat-message-quote-context .chat-message-nested-references-list .chat-message-reference {
    background: transparent;
    border: none;
    outline: none;
    box-shadow: none;
}

.chat-message-quote-context .chat-message-nested-references-list .chat-message-reference:hover {
    background: var(--chat-quote-context-bg-hover, rgba(245, 158, 11, 0.14));
}

.chat-message-quote-stack .chat-message-references-list .chat-message-reference:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
}

/* Antwort-Zeile (blau, ohne Kontext-Block): Referenzzeilen nur Hover, kein eigener Kartenhintergrund */
.chat-message-quote-stack .chat-message-quote-primary .chat-message-references-list .chat-message-reference,
.chat-message-quote-stack .chat-message-quote-primary .chat-message-nested-references-list .chat-message-reference {
    background: transparent;
    border: none;
    outline: none;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-references-list .chat-message-reference:hover,
.chat-message-quote-stack .chat-message-quote-primary .chat-message-nested-references-list .chat-message-reference:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
}

/* Referenzen in der Antwort-Box (gelbe Kontext-Fläche): gleiche Zeilen/Hover wie quote-context */
.chat-message-quote-nested--reply-target-refs
    .chat-message-nested-references.is-expanded
    .chat-message-references--in-quote-stack
    .chat-message-references-list
    .chat-message-reference,
.chat-message-quote-nested--reply-target-refs
    .chat-message-nested-references.is-expanded
    .chat-message-references--in-quote-stack
    .chat-message-nested-references-list
    .chat-message-reference {
    background: transparent;
    border: none;
    outline: none;
}

.chat-message-quote-nested--reply-target-refs
    .chat-message-nested-references.is-expanded
    .chat-message-references--in-quote-stack
    .chat-message-references-list
    .chat-message-reference:hover,
.chat-message-quote-nested--reply-target-refs
    .chat-message-nested-references.is-expanded
    .chat-message-references--in-quote-stack
    .chat-message-nested-references-list
    .chat-message-reference:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
}

/*
 * Hover nur auf der tatsächlich gehoverten Zeile: Vorfahren bekommen ebenfalls :hover (CSS),
 * solange der Zeiger auf einem Nachfahren liegt — Vorfahren-Hover zurücksetzen.
 */
.chat-message-quote-context-body .chat-message-references-list .chat-message-reference:has(.chat-message-reference:hover),
.chat-message-quote-stack .chat-message-references-list .chat-message-reference:has(.chat-message-reference:hover),
.chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference:has(.chat-message-reference:hover) {
    background: transparent !important;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-references-list .chat-message-reference:has(.chat-message-reference:hover),
.chat-message-quote-stack .chat-message-quote-primary .chat-message-nested-references-list .chat-message-reference:has(.chat-message-reference:hover),
.chat-message-quote-nested--reply-target-refs .chat-message-references-list .chat-message-reference:has(.chat-message-reference:hover),
.chat-message-quote-nested--reply-target-refs .chat-message-nested-references-list .chat-message-reference:has(.chat-message-reference:hover) {
    background: transparent !important;
}

.chat-message-quote-context-body .chat-message-references-list .chat-message-reference:has(.chat-message-reply:hover),
.chat-message-quote-stack .chat-message-references-list .chat-message-reference:has(.chat-message-reply:hover),
.chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference:has(.chat-message-reply:hover) {
    background: transparent !important;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-references-list .chat-message-reference:has(.chat-message-reply:hover),
.chat-message-quote-stack .chat-message-quote-primary .chat-message-nested-references-list .chat-message-reference:has(.chat-message-reply:hover),
.chat-message-quote-nested--reply-target-refs .chat-message-references-list .chat-message-reference:has(.chat-message-reply:hover),
.chat-message-quote-nested--reply-target-refs .chat-message-nested-references-list .chat-message-reference:has(.chat-message-reply:hover) {
    background: transparent !important;
}

.chat-message-quote-stack .chat-message-reply:has(.chat-message-reply:hover),
.chat-message-quote-stack .chat-message-reply:has(.chat-message-reference:hover) {
    background: transparent !important;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-reply:has(.chat-message-reply:hover),
.chat-message-quote-stack .chat-message-quote-primary .chat-message-reply:has(.chat-message-reference:hover),
.chat-message-quote-nested--reply-target-refs .chat-message-reply:has(.chat-message-reply:hover),
.chat-message-quote-nested--reply-target-refs .chat-message-reply:has(.chat-message-reference:hover) {
    background: transparent !important;
}

/* Zeile mit aufgeklappten Unter-Referenzen: Faden-Seite bleibt flach */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-references-list .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-context-body .chat-message-references-list .chat-message-reference:has(> .chat-message-nested-references.is-expanded) {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-top-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-references-list .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-context-body .chat-message-references-list .chat-message-reference:has(> .chat-message-nested-references.is-expanded) {
    border-top-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
}

.chat-message-quote-stack .chat-message-reference--unavailable {
    opacity: 0.88;
}

.chat-message-quote-stack .chat-message-reference--unavailable .chat-message-reference-text,
.chat-message-quote-stack .chat-message-reference--unavailable .chat-message-inline-text {
    color: #94a3b8 !important;
    font-weight: 500;
}

.chat-message-quote-stack .chat-message-reference--unavailable .chat-message-avatar.chat-message-inline-avatar {
    opacity: 0.72;
    filter: grayscale(0.25);
}

.chat-message-quote-stack .chat-message-reference-header {
    gap: 8px;
}

.chat-message-quote-stack .chat-message-reference-toggle {
    flex-shrink: 0;
    width: var(--kinma-quote-compact-chevron-size);
    height: var(--kinma-quote-compact-chevron-size);
    min-width: var(--kinma-quote-compact-chevron-size);
    border: none;
    background: transparent;
    border-radius: 0;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    margin-left: auto;
}

/* Zitat-Stack: kein position:absolute-Toggle aus den Basis-Regeln — volle Zeilenbreite, Chevron rechts */
.chat-message-quote-stack .chat-message-references-toggle {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    bottom: auto !important;
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: var(--kinma-quote-compact-row-min-h) !important;
    height: auto !important;
    max-height: none !important;
    border: none !important;
    background: transparent !important;
    border-radius: 0 !important;
    box-sizing: border-box !important;
    z-index: 1 !important;
}

.chat-message-quote-row--references-toggle {
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    box-sizing: border-box;
}

.chat-message-quote-row--references-toggle .chat-message-references-toggle {
    position: relative !important;
    top: auto !important;
    right: auto !important;
}

/* Einzel-Referenz (ohne „X Referenzen“-Gruppierung): ohne Rahmen */
.chat-message-quote-stack .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle {
    background: transparent !important;
    border: none !important;
    outline: none !important;
    border-radius: var(--kinma-quote-card-r, 20px) !important;
    box-shadow: none !important;
}

.chat-message-quote-stack .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06)) !important;
}

.chat-message-quote-stack .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle[data-expanded='true'] {
    background: transparent !important;
}

.chat-message-quote-stack .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle[data-expanded='true']:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06)) !important;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle,
.chat-message-quote-nested--reply-target-refs .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle {
    border: none !important;
    outline: none !important;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle:hover,
.chat-message-quote-stack .chat-message-quote-primary .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle[data-expanded='true']:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06)) !important;
}

/* Mehrere Kontextnachrichten: Toggle über volle Kartenbreite, Chevron am Rand */
.chat-message-quote-stack .chat-message-references--in-quote-stack.chat-message-references--multi-collapse {
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    height: var(--kinma-quote-compact-row-min-h);
    min-height: var(--kinma-quote-compact-row-min-h);
    max-height: var(--kinma-quote-compact-row-min-h);
    min-width: 0;
    justify-content: flex-start;
    align-items: center;
    gap: var(--kinma-quote-compact-row-gap);
    padding: var(--kinma-quote-compact-row-py) var(--kinma-quote-compact-row-px);
    box-sizing: border-box;
    background: transparent !important;
    border: none !important;
    outline: none !important;
    border-radius: var(--kinma-quote-card-r, 20px);
    margin-bottom: 0;
    z-index: 1;
    outline: none !important;
    box-shadow: none !important;
    appearance: none;
    -webkit-appearance: none;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-people,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-people {
    order: 0;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-label,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-label {
    order: 1;
    flex: 1 1 auto;
    min-width: 0;
    text-align: left;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle .toggle-icon,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle .toggle-icon {
    order: 2;
    margin-left: auto !important;
    color: #1a1a1a;
    width: var(--kinma-quote-compact-chevron-size);
    height: var(--kinma-quote-compact-chevron-size);
    flex-shrink: 0;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-inline-glyph--reference,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-inline-glyph--reference {
    width: var(--kinma-quote-compact-glyph-size);
    height: var(--kinma-quote-compact-glyph-size);
    min-width: var(--kinma-quote-compact-glyph-size);
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-people,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-people {
    height: var(--kinma-quote-compact-inline-size);
    align-items: center;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-person,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle .chat-message-references-toggle-person {
    width: var(--kinma-quote-compact-inline-size);
    height: var(--kinma-quote-compact-inline-size);
    min-width: var(--kinma-quote-compact-inline-size);
    max-width: var(--kinma-quote-compact-inline-size);
    min-height: var(--kinma-quote-compact-inline-size);
    max-height: var(--kinma-quote-compact-inline-size);
}

.chat-message-quote-stack .chat-message-quote-row--references-toggle {
    align-items: center;
    min-height: var(--kinma-quote-compact-row-min-h);
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    box-sizing: border-box;
}

/* Antwort- und Kontext-Karten: Zeilen über volle Breite */
.chat-message-quote-stack .chat-message-quote-block--context .chat-message-quote-context,
.chat-message-quote-stack .chat-message-quote-block--primary .chat-message-quote-primary {
    align-self: stretch;
    width: 100%;
    max-width: min(100%, var(--chat-quote-card-max-width));
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-row,
.chat-message-quote-stack .chat-message-quote-context .chat-message-quote-row {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-reply {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-context-body,
.chat-message-quote-stack .chat-message-quote-primary-body {
    align-items: stretch;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-context-body,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary-body {
    align-items: stretch;
}

/* Eingeklappte Referenz-Karte = exakt eine kompakte Zeile (wie Antwort) */
.chat-message-quote-stack
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)) {
    min-height: var(--kinma-quote-compact-row-min-h);
    box-sizing: border-box;
}

/* Eingeklappte Master-Liste: Grid-Collapse (0fr), kein max-height — sonst keine Auf-/Zuklapp-Animation */
.chat-message-quote-stack
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded))
    > .chat-message-references-list.chat-message-quote-collapse-target--collapsed,
.chat-message-quote-above
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded))
    > .chat-message-references-list.chat-message-quote-collapse-target--collapsed {
    margin: 0 !important;
    padding: 0 !important;
}

.chat-message-quote-stack .chat-message-quote-identity .chat-message-inline-avatar {
    width: var(--kinma-quote-compact-inline-size);
    height: var(--kinma-quote-compact-inline-size);
    min-width: var(--kinma-quote-compact-inline-size);
    max-width: var(--kinma-quote-compact-inline-size);
    min-height: var(--kinma-quote-compact-inline-size);
    max-height: var(--kinma-quote-compact-inline-size);
}

.chat-message-quote-stack .chat-message-inline-glyph {
    width: var(--kinma-quote-compact-glyph-size);
    height: var(--kinma-quote-compact-glyph-size);
    min-width: var(--kinma-quote-compact-glyph-size);
}

.chat-message-quote-stack .chat-message-inline-glyph svg,
.chat-message-quote-stack .chat-message-inline-glyph--reference svg {
    width: 14px;
    height: 14px;
}

/* Referenz-Pillen & -Zeilen: gleiche Typo, Icons und Avatare wie kompakte Antwort-Zeile */
.chat-message-quote-stack .chat-message-references-toggle-label {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.35;
    color: #1a1a1a;
}

.chat-message-quote-stack .chat-message-avatar.chat-message-inline-avatar,
.chat-message-quote-stack .chat-message-avatar.chat-message-references-toggle-person {
    width: var(--kinma-quote-compact-inline-size);
    height: var(--kinma-quote-compact-inline-size);
    min-width: var(--kinma-quote-compact-inline-size);
    max-width: var(--kinma-quote-compact-inline-size);
    min-height: var(--kinma-quote-compact-inline-size);
    max-height: var(--kinma-quote-compact-inline-size);
    font-size: 11px;
}

.chat-message-quote-stack .chat-message-references-toggle-people {
    display: inline-flex;
    align-items: center;
    height: var(--kinma-quote-compact-inline-size);
    margin-right: 0;
    flex-shrink: 0;
}

.chat-message-quote-stack .chat-message-references-toggle-person + .chat-message-references-toggle-person {
    margin-left: -8px;
}

.chat-message-quote-stack .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle {
    position: relative;
    top: auto;
    right: auto;
    left: auto;
    width: auto;
    max-width: 100%;
    min-width: 0;
    height: var(--kinma-quote-compact-row-min-h);
    min-height: var(--kinma-quote-compact-row-min-h);
    padding: var(--kinma-quote-compact-row-py) var(--kinma-quote-compact-row-px);
    gap: var(--kinma-quote-compact-row-gap);
    align-items: center;
    justify-content: flex-start;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-references-list .chat-message-reference,
.chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference {
    padding: var(--kinma-quote-compact-row-py) var(--kinma-quote-compact-row-px);
    min-height: var(--kinma-quote-compact-row-min-h);
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-reference-header {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-reference-header,
.chat-message-quote-stack .chat-message-reference-content {
    align-items: center;
    gap: var(--kinma-quote-compact-row-gap);
    min-height: var(--kinma-quote-compact-inline-size);
}

.chat-message-quote-stack .chat-message-reference-content {
    display: flex;
    flex: 1;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-reference-content > .chat-message-reference-toggle {
    margin-left: auto;
}

.chat-message-quote-stack .chat-message-reference-toggle {
    width: var(--kinma-quote-compact-chevron-size);
    height: var(--kinma-quote-compact-chevron-size);
    min-width: var(--kinma-quote-compact-chevron-size);
    min-height: var(--kinma-quote-compact-chevron-size);
    margin-top: 0;
    padding: 0;
}

.chat-message-quote-stack .chat-message-reference-toggle .toggle-icon {
    width: var(--kinma-quote-compact-chevron-size);
    height: var(--kinma-quote-compact-chevron-size);
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle[data-expanded='true'],
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle[data-expanded='true'] {
    background: transparent !important;
    outline: none !important;
    box-shadow: none !important;
}

/*
 * Multi-collapse-Toggle: Abdunkeln nur wenn die Liste aufgeklappt ist.
 * Eingeklappt kommt die Hover-Farbe allein von .chat-message-references--in-quote-stack — sonst doppeltes Highlight (Padding + Button).
 */
.chat-message-quote-stack
    .chat-message-references--in-quote-stack:has(> .chat-message-references-list.is-expanded)
    .chat-message-references--multi-collapse
    .chat-message-references-toggle:hover,
.chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack:has(> .chat-message-references-list.is-expanded)
    .chat-message-references--multi-collapse
    .chat-message-references-toggle:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06)) !important;
    outline: none !important;
    box-shadow: none !important;
}

.chat-message-quote-stack
    .chat-message-references--in-quote-stack:has(> .chat-message-references-list.is-expanded)
    .chat-message-references--multi-collapse
    .chat-message-references-toggle[data-expanded='true']:hover,
.chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack:has(> .chat-message-references-list.is-expanded)
    .chat-message-references--multi-collapse
    .chat-message-references-toggle[data-expanded='true']:hover {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06)) !important;
}

/* Eingeklappte „X Referenzen“-Pille: einheitlicher Hover für Antwort- und Referenz-Karten */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack
    .chat-message-quote-context
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):hover,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack
    .chat-message-quote-context
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):focus-within,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):hover,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):focus-within {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
    border-radius: 0 var(--kinma-quote-card-r, 20px) var(--kinma-quote-card-r, 20px) 0;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack
    .chat-message-quote-context
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):hover,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack
    .chat-message-quote-context
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):focus-within,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):hover,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded)):focus-within {
    background: var(--kinma-quote-interactive-hover, rgba(26, 26, 26, 0.06));
    border-radius: var(--kinma-quote-card-r, 20px) 0 0 var(--kinma-quote-card-r, 20px);
}

.chat-message-quote-stack
    .chat-message-references--in-quote-stack:has(> .chat-message-references-list.is-expanded)
    .chat-message-references--multi-collapse
    .chat-message-references-toggle:focus-visible,
.chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack:has(> .chat-message-references-list.is-expanded)
    .chat-message-references--multi-collapse
    .chat-message-references-toggle:focus-visible {
    background: var(--kinma-quote-interactive-hover-strong, rgba(26, 26, 26, 0.08)) !important;
    outline: none !important;
    box-shadow: none !important;
}

.chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle:focus:not(:focus-visible),
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle:focus:not(:focus-visible) {
    background: transparent !important;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-references--multi-collapse .chat-message-references-toggle,
.chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle {
    border: none !important;
    outline: none !important;
}

.chat-message-references-toggle-label {
    font-size: 12px;
    font-weight: 700;
    color: #1a1a1a;
    text-align: left;
    line-height: 1.3;
    flex: 0 0 auto;
    min-width: 0;
}

.chat-message-references-toggle-people {
    display: inline-flex;
    align-items: center;
    margin-right: 2px;
}

.chat-message-references-toggle-person + .chat-message-references-toggle-person {
    margin-left: -5px;
}

.chat-message-quote-nested--reply-target-refs .chat-message-references--in-quote-stack {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    align-items: stretch;
}

/* Kontext der zitierten Nachricht: keine Index-Zahlen; Gruppierungs-Toggle („X Referenzen“) bleibt */
.chat-message-references--reply-target-context .chat-message-reference-num {
    display: none !important;
}

.chat-message-references--reply-target-context > .chat-message-references-list {
    margin-top: 0;
    padding-top: 0;
}

.chat-message-quote-nested--reply-target-refs .chat-message-quote-section-label--reply-target {
    display: none !important;
    margin: 0;
    padding: 0 var(--kinma-quote-compact-row-px, 10px) 4px;
    width: 100%;
    max-width: 100%;
    align-self: stretch;
    text-align: left;
    box-sizing: border-box;
}

/* In der Antwort-Box (blau): „Weiterer Kontext“ mit Abstand zur Profil-/Faden-Seite */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs .chat-message-quote-section-label--reply-target {
    text-align: right;
    padding-left: var(--kinma-quote-compact-row-px, 10px);
    padding-right: calc(var(--kinma-quote-compact-row-px, 10px) + 4px);
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs .chat-message-quote-section-label--reply-target {
    text-align: left;
    padding-left: calc(var(--kinma-quote-compact-row-px, 10px) + 4px);
    padding-right: var(--kinma-quote-compact-row-px, 10px);
}

/* Kontext-Block in der Antwort-Box: volle Breite, unten an der blauen Karte */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs {
    align-self: stretch;
    align-items: stretch;
    width: 100%;
    max-width: 100%;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references {
    align-self: stretch;
    width: 100%;
    max-width: 100%;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references {
    align-self: stretch;
    width: 100%;
    max-width: 100%;
}

/* Antwort-Zitat: ausgeklappter Kontext gleiche Fläche wie Referenz-Gruppierung (Karte unter der Reply-Zeile) */
.chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs.chat-message-quote-nested {
    border-top: none !important;
    background: transparent !important;
    margin-top: 0;
    padding-top: 0;
}

.chat-message-quote-stack .chat-message-quote-primary-body:has(.chat-message-quote-nested--reply-target-refs) {
    gap: 0;
}

/* Antwort-Kontext: gleiche Grid-Collapse-Animation wie .chat-message-references-list */
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references {
    display: grid !important;
    grid-template-rows: 1fr;
    width: 100%;
    max-width: 100%;
    min-height: 0;
    margin: 0 !important;
    padding: 0 !important;
    border: none !important;
    background: transparent !important;
    box-sizing: border-box;
    position: relative;
    overflow: hidden;
    opacity: 1;
    transition:
        grid-template-rows 0.16s ease,
        opacity 0.12s ease;
}

.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.chat-message-quote-collapse-target--collapsed {
    grid-template-rows: 0fr;
    opacity: 0;
    pointer-events: none;
}

.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references > .chat-message-quote-collapse-inner {
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    min-height: 0;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
}

/* Aufklapp-Animation: gesamte wachsende Fläche gelb (kein Blau darunter) */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded {
    background: linear-gradient(
        to left,
        var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 100%
    ) !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded {
    background: linear-gradient(
        to left,
        var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 0%,
        color-mix(in srgb, var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
            var(--kinma-chat-wall-gradient-mid, 42%),
        var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade, 72%)
    ) !important;
}

/* Jede Referenz-Liste / verschachtelte Referenz-Box in der Antwort: Grid-Collapse wie außerhalb */
.chat-message-quote-nested--reply-target-refs .chat-message-references-list,
.chat-message-quote-nested--reply-target-refs .chat-message-reference > .chat-message-nested-references {
    display: grid !important;
    grid-template-rows: 1fr;
    opacity: 1;
    overflow: hidden;
    min-height: 0;
    transition:
        grid-template-rows 0.16s ease,
        opacity 0.12s ease;
}

.chat-message-quote-nested--reply-target-refs .chat-message-references-list.chat-message-quote-collapse-target--collapsed,
.chat-message-quote-nested--reply-target-refs .chat-message-reference > .chat-message-nested-references.chat-message-quote-collapse-target--collapsed {
    grid-template-rows: 0fr;
    opacity: 0;
    pointer-events: none;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    min-height: 0 !important;
}

.chat-message-quote-nested--reply-target-refs .chat-message-references-list > .chat-message-quote-collapse-inner,
.chat-message-quote-nested--reply-target-refs .chat-message-reference > .chat-message-nested-references > .chat-message-nested-references-list {
    min-height: 0;
    overflow: hidden;
}

/* Master-Liste: kein max-height-Hack — Animation über grid-template-rows */
.chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack.chat-message-references--multi-collapse:not(:has(> .chat-message-references-list.is-expanded))
    > .chat-message-references-list {
    flex: unset;
    max-height: unset;
}

/* Antwort-Box mit Kontext: von oben nach unten aufklappen */
.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs) {
    justify-content: flex-start;
    min-height: 0;
}

.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs) .chat-message-quote-primary-body {
    justify-content: flex-start;
    min-height: 0;
    width: 100%;
    max-width: 100%;
    align-items: stretch;
    box-sizing: border-box;
    flex: 1 1 auto;
}

/* Ausgeklappte Antwort-Referenzen: blaue Karte + Reply-Zeile über volle Quote-Breite */
.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) {
    width: 100%;
    max-width: min(100%, var(--chat-quote-card-max-width));
    align-self: stretch;
    box-sizing: border-box;
    justify-content: flex-start;
    min-height: 0;
    height: auto;
}

.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-primary-body {
    width: 100%;
    max-width: 100%;
    align-items: stretch;
    box-sizing: border-box;
    justify-content: flex-start;
    flex: 1 1 auto;
    min-height: 0;
    height: auto;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-primary-body {
    align-items: stretch;
}

.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-primary-body > .chat-message-quote-row,
.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-primary-body > .chat-message-quote-nested--reply-target-refs {
    align-self: stretch;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-row {
    width: 100%;
    max-width: 100%;
}

.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-row > .chat-message-reply,
.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-reply.has-expanded-nested {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-nested--reply-target-refs {
    align-self: stretch;
    align-items: stretch;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-nested--reply-target-refs {
    align-self: stretch;
    align-items: stretch;
}

.chat-message-quote-stack .chat-message-quote-primary:has(.chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded) .chat-message-quote-nested--reply-target-refs .chat-message-quote-section-label--reply-target {
    width: 100%;
    max-width: 100%;
}

/* Gelbe Kontext-Fläche in der Antwort-Zeile — Rundung am äußeren aufklappbaren Block */
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references.chat-message-references--in-quote-stack,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references.chat-message-references--in-quote-stack {
    position: relative;
    background: transparent !important;
    margin: 0 !important;
    padding: 0 !important;
    min-width: 0;
    max-width: 100%;
    width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    border: none !important;
    border-top: none !important;
    border-radius: 0 !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded {
    border-radius: var(--kinma-quote-card-r, 20px) 0 var(--kinma-quote-card-r, 20px) var(--kinma-quote-card-r, 20px) !important;
}

.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded {
    border-radius: 0 var(--kinma-quote-card-r, 20px) var(--kinma-quote-card-r, 20px) var(--kinma-quote-card-r, 20px) !important;
}

/* Eingeklappte „X Referenzen“-Zeile: kompakt, Toggle mit Karten-Rundung */
.chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references--in-quote-stack:not(:has(> .chat-message-references-list.is-expanded)) {
    width: 100%;
    max-width: 100%;
    cursor: pointer;
}

.chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack:not(:has(> .chat-message-references-list.is-expanded))
    .chat-message-references--multi-collapse
    .chat-message-quote-row--references-toggle {
    width: 100%;
}

.chat-message-quote-nested--reply-target-refs
    .chat-message-references--in-quote-stack:not(:has(> .chat-message-references-list.is-expanded))
    .chat-message-references--multi-collapse
    .chat-message-references-toggle {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* Frühere Linie am äußeren .nested-references entfällt — Faden nur über bestehende Regeln an der Liste / verschachtelten Zeilen */
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references.is-expanded::before {
    display: none !important;
}

/* Referenzen im Antwort-Kontext: umbrechen, nicht aus der grauen Karte schneiden */
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references--in-quote-stack,
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-nested-references-list,
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references-list {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-reference,
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-reply {
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
}

.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-reference-text.chat-message-inline-text,
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-reply-text,
.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-inline-text {
    white-space: normal;
    word-break: break-word;
    overflow-wrap: break-word;
    text-overflow: unset;
}

.chat-message-quote-stack .chat-message-quote-nested--reply-target-refs > .chat-message-nested-references > * {
    position: relative;
    z-index: 1;
}

.chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references:not(.is-expanded) .chat-message-references--in-quote-stack {
    margin: 0;
    padding: 0;
    border-top: none;
    background: transparent;
}

.chat-message-reply-context-hint {
    margin-top: 4px;
    font-size: 11px;
    font-weight: 600;
    color: #64748b;
    line-height: 1.3;
}

.chat-reaction-picker {
    position: fixed;
    background: #ffffff;
    border-radius: 24px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
    padding: 8px;
    display: flex;
    gap: 4px;
    z-index: 10001;
    animation: contextMenuFadeIn 0.15s ease-out;
}

.chat-reaction-emoji {
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: 50%;
    cursor: pointer;
    font-size: 20px;
    transition: all 0.2s ease;
}

.chat-reaction-emoji:hover {
    background: #f8f9fa;
    transform: scale(1.2);
}

.chat-reaction-emoji:active {
    transform: scale(1.1);
}

.chat-message-reactions {
    display: flex;
    align-items: center;
    gap: 4px;
    margin-top: 4px;
    flex-wrap: wrap;
}

.chat-message-reaction {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px 6px;
    background: rgba(0, 0, 0, 0.05);
    border-radius: 12px;
    font-size: 12px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.chat-message-reaction:hover {
    background: rgba(0, 0, 0, 0.1);
}

.chat-message-reaction-emoji {
    font-size: 14px;
}

.chat-message-reaction-count {
    font-size: 11px;
    color: #6c757d;
    font-weight: 500;
}

.chat-message-reaction-active {
    background: rgba(0, 123, 255, 0.15);
    border: 1px solid rgba(0, 123, 255, 0.3);
}

/* Eingangsblasen (nicht KI-Modus): Reactions auf dunklem Grund */
.chat-popup:not(.ai-mode) .chat-message-bot .chat-message-content .chat-message-reaction {
    background: rgba(255, 255, 255, 0.14);
}

.chat-popup:not(.ai-mode) .chat-message-bot .chat-message-content .chat-message-reaction:hover {
    background: rgba(255, 255, 255, 0.22);
}

.chat-popup:not(.ai-mode) .chat-message-bot .chat-message-content .chat-message-reaction-count {
    color: rgba(255, 255, 255, 0.88);
}

.chat-popup:not(.ai-mode) .chat-message-bot .chat-message-content .chat-message-reaction-active {
    background: rgba(96, 165, 250, 0.22);
    border: 1px solid rgba(96, 165, 250, 0.45);
}

.chat-message,
.chat-date-separator,
.chat-new-unread-divider {
    transition: filter 0.22s ease, opacity 0.22s ease;
}

#chatMessages > .chat-message,
.chat-messages > .chat-message {
    content-visibility: auto;
    contain-intrinsic-size: auto 80px;
}

/* Zustell-Häkchen über dem Avatar: nicht aus dem Zeilen-Box schneiden (content-visibility / absolutes bottom:100%) */
#chatMessages > .chat-message.chat-message-user:has(.chat-message-delivery-anchor--on-avatar),
.chat-messages > .chat-message.chat-message-user:has(.chat-message-delivery-anchor--on-avatar) {
    content-visibility: visible;
    overflow: visible;
}

.chat-messages.chat-messages-focus-active,
#chatMessages.chat-messages-focus-active {
    isolation: isolate;
}

#chatMessages.chat-messages-focus-active > .chat-message:not(.chat-message-focus-target),
#chatMessages.chat-messages-focus-active > .chat-date-separator,
#chatMessages.chat-messages-focus-active > .chat-new-unread-divider,
#chatMessages.chat-messages-focus-active > .chat-conversation-start,
.chat-messages.chat-messages-focus-active > .chat-message:not(.chat-message-focus-target),
.chat-messages.chat-messages-focus-active > .chat-date-separator,
.chat-messages.chat-messages-focus-active > .chat-new-unread-divider,
.chat-messages.chat-messages-focus-active > .chat-conversation-start {
    filter: blur(1px);
    opacity: 0.3;
    pointer-events: none;
}

.chat-message-focus-target {
    /* Innerhalb .chat-messages (z-index 1), unter Header/Eingabe (z-index 3–4) */
    z-index: 2;
    pointer-events: auto;
}

.chat-message-references {
    display: flex;
    flex-direction: column;
    gap: 4px;
    margin-top: 6px;
    padding-top: 6px;
    border-top: none;
    position: relative;
}

.chat-message-references::before {
    display: none;
}

.chat-message-references-toggle {
    position: absolute;
    top: 2px;
    right: 4px;
    width: auto;
    min-width: 22px;
    height: 22px;
    border: none;
    background: rgba(26, 26, 26, 0.04);
    cursor: pointer;
    padding: 0 5px;
    gap: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: row;
    z-index: 10;
    transition: background 0.15s ease;
    flex-shrink: 0;
    border-radius: 6px;
}

.chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle .chat-message-inline-glyph--reference {
    width: 14px;
    height: 14px;
    min-width: 14px;
}

.chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle .chat-message-inline-glyph--reference svg {
    width: 11px;
    height: 11px;
}

.chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle .chat-message-inline-glyph--reference {
    order: 0;
}

.chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle .toggle-icon {
    order: 1;
}

.chat-message-references-toggle:hover {
    background: rgba(26, 26, 26, 0.08);
}

.chat-message-references-toggle .toggle-icon {
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    transform: rotate(0deg);
    color: #64748b;
    width: 8px;
    height: 8px;
    opacity: 0.85;
}

.chat-message-references-toggle[data-expanded="true"] .toggle-icon {
    transform: rotate(90deg);
    opacity: 1;
}

.chat-message-references-toggle:hover .toggle-icon {
    opacity: 1;
}

.chat-message-references-list {
    display: flex;
    flex-direction: column;
    gap: 4px;
    width: 100%;
}

.chat-message-reference {
    display: flex;
    flex-direction: column;
    gap: 0;
    padding: 5px 10px;
    margin-left: 0;
    background: rgba(26, 26, 26, 0.03);
    border: none;
    border-radius: 6px;
    border-left: 2px solid rgba(100, 116, 139, 0.35);
    cursor: pointer;
    transition: background 0.15s ease;
    font-size: 11px;
    position: relative;
}

.chat-message-reference:hover {
    background: rgba(26, 26, 26, 0.055);
}

.chat-message-reference.has-nested-references {
    position: relative;
}

.chat-message-reply.has-expanded-nested,
.chat-message-reference.has-expanded-nested {
    border-radius: 10px !important;
}

/* Quote-Stack: keine Radius-Morph beim Aufklappen von Unter-Referenzen */
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-reference.has-expanded-nested,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-reference.has-expanded-nested,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs .chat-message-reference.has-expanded-nested,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-reply.has-expanded-nested,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-reply.has-expanded-nested,
.chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs .chat-message-reply.has-expanded-nested {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-top-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
}

.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-reference.has-expanded-nested,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-reference.has-expanded-nested,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs .chat-message-reference.has-expanded-nested,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-reply.has-expanded-nested,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-reply.has-expanded-nested,
.chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs .chat-message-reply.has-expanded-nested {
    border-top-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
}

.chat-message-reference-header {
    display: flex;
    align-items: flex-start;
    gap: 2px;
    width: 100%;
    pointer-events: auto;
    position: relative;
    z-index: 1;
}

.chat-message-reply.has-nested-references {
    position: relative;
}

.chat-message-reply.has-nested-references.has-expanded-nested::after,
.chat-message-reference.has-nested-references.has-expanded-nested::after {
    display: none;
}

.chat-message-reference.has-nested-references {
    position: relative;
}

.chat-message-nested-references {
    position: relative;
    width: 100%;
    padding-left: 10px;
    padding-top: 0;
    margin: 6px 0 0 6px;
    border-left: 1px solid rgba(148, 163, 184, 0.45);
    border-top: none;
    display: none;
}

.chat-message-nested-references.is-expanded {
    display: block !important;
}

.chat-message-references-list.is-expanded {
    display: flex !important;
}

/* Quote-Thread: Grid-Collapse statt display none/flex (überschreibt Legacy oben) */
.chat-message-quote-above .chat-message-references-list,
.chat-message-quote-above .chat-message-references-list.is-expanded,
.chat-message-quote-stack .chat-message-references-list,
.chat-message-quote-stack .chat-message-references-list.is-expanded {
    display: grid !important;
}

.chat-message-quote-above .chat-message-nested-references,
.chat-message-quote-above .chat-message-nested-references.is-expanded,
.chat-message-quote-stack .chat-message-nested-references,
.chat-message-quote-stack .chat-message-nested-references.is-expanded {
    display: grid !important;
}

.chat-message-nested-references.is-expanded::before {
    display: none;
}

.chat-message-nested-references .chat-message-reference.has-nested-references.has-expanded-nested::after,
.chat-message-nested-references .chat-message-nested-references.is-expanded::before {
    display: none;
}

.chat-message-nested-references .chat-message-nested-references {
    padding-left: 10px;
    margin-left: 6px;
    border-left: 1px solid rgba(148, 163, 184, 0.28);
}

.chat-message-reference-toggle {
    width: 20px;
    height: 20px;
    min-width: 20px;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: background 0.15s ease;
    flex-shrink: 0;
    margin-right: 0;
    border-radius: 0;
    position: relative;
    pointer-events: auto;
    margin-left: 6px;
}

.chat-message-reply-toggle {
    width: 20px;
    height: 20px;
    min-width: 20px;
    border: none;
    background: transparent;
    cursor: pointer;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10;
    transition: background 0.15s ease;
    flex-shrink: 0;
    margin-right: 0;
    border-radius: 0;
    position: relative;
    pointer-events: auto;
    margin-left: 6px;
}

.chat-message-reply-toggle:hover {
    background: transparent;
}

.chat-message-reply-toggle .toggle-icon {
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    transform: rotate(0deg);
    color: #1a1a1a;
    width: 12px;
    height: 12px;
    opacity: 0.85;
}

.chat-message-reply-toggle[data-expanded="true"] .toggle-icon {
    transform: rotate(90deg);
    opacity: 1;
}

.chat-message-reply-toggle:hover .toggle-icon {
    opacity: 1;
}

.chat-message-reference-toggle:hover {
    background: transparent;
}

.chat-message-reference-toggle .toggle-icon {
    transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    transform: rotate(0deg);
    color: #1a1a1a;
    width: 12px;
    height: 12px;
    opacity: 0.85;
}

.chat-message-reference-toggle[data-expanded="true"] .toggle-icon {
    transform: rotate(90deg);
    opacity: 1;
}

.chat-message-reference-toggle:hover .toggle-icon {
    opacity: 1;
}

.chat-message-reference-spacer {
    width: 0;
    min-width: 0;
    flex-shrink: 0;
}

.chat-message-reference-line {
    width: 0;
    min-width: 0;
    margin: 0;
    overflow: hidden;
    opacity: 0;
    pointer-events: none;
    flex-shrink: 0;
    align-self: stretch;
    min-height: 1em;
}

.chat-message-reference-line:hover {
    opacity: 0;
}

.chat-message-reference-content {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 1;
    min-width: 0;
    padding-left: 0;
}

.chat-message-reference-name {
    font-size: 11px;
    font-weight: 600;
    color: #1a1a1a;
    margin-bottom: 2px;
    line-height: 1.25;
}

.chat-message-reference-text {
    font-size: 11px;
    color: #64748b;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    line-height: 1.35;
}

.chat-message-nested-references[style*="block"] {
    display: block !important;
}

.chat-message-nested-references-list {
    display: flex;
    flex-direction: column;
    gap: 2px;
    width: 100%;
}

.chat-message-nested-references-list[data-depth="1"] {
    margin-left: 0;
}

.chat-message-nested-references-list[data-depth="2"] {
    margin-left: 0;
}

.chat-message-nested-references-list[data-depth="3"] {
    margin-left: 0;
}

.chat-message-nested-references-list[data-depth="4"] {
    margin-left: 0;
}

.chat-message-nested-references-list[data-depth="5"] {
    margin-left: 0;
}

.chat-message-nested-references .chat-message-nested-references {
    margin-top: 6px;
    border-top: none;
}

.chat-message-nested-references .chat-message-nested-references .chat-message-nested-references {
    border-top: none;
}

.chat-message-nested-references .chat-message-nested-references .chat-message-nested-references .chat-message-nested-references {
    border-top: none;
}

.chat-message-reference-selector {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10002;
    animation: fadeIn 0.2s ease-out;
}

.chat-reference-selector-content {
    background: #ffffff;
    border-radius: 12px;
    width: 90%;
    max-width: 600px;
    max-height: 80vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    animation: slideUp 0.2s ease-out;
}

.chat-reference-selector-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid #e9ecef;
}

.chat-reference-selector-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-reference-selector-close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: 6px;
    cursor: pointer;
    color: #6c757d;
    font-size: 24px;
    line-height: 1;
    transition: all 0.2s ease;
}

.chat-reference-selector-close:hover {
    background: #f8f9fa;
    color: #1a1a1a;
}

.chat-reference-selector-body {
    padding: 20px 24px;
    overflow-y: auto;
    flex: 1;
}

.chat-reference-selector-hint {
    margin: 0 0 16px 0;
    color: #1a1a1a;
    font-size: 14px;
}

.chat-reference-messages-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
    max-height: 400px;
    overflow-y: auto;
}

.chat-reference-message-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border: 2px solid #e9ecef;
    border-radius: 8px;
    cursor: pointer;
    transition: all 0.2s ease;
    background: #ffffff;
}

.chat-reference-message-item:hover {
    border-color: #007bff;
    background: #f8f9fa;
}

.chat-reference-message-item.selected {
    border-color: #007bff;
    background: rgba(0, 123, 255, 0.05);
}

.chat-reference-message-checkbox {
    width: 20px;
    height: 20px;
    border: 2px solid #dee2e6;
    border-radius: 4px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    transition: all 0.2s ease;
    background: #ffffff;
}

.chat-reference-message-item.selected .chat-reference-message-checkbox {
    background: #007bff;
    border-color: #007bff;
    color: #ffffff;
}

.chat-reference-message-item.selected .chat-reference-message-checkbox svg {
    display: block;
}

.chat-reference-message-item:not(.selected) .chat-reference-message-checkbox svg {
    display: none;
}

.chat-reference-message-content {
    flex: 1;
    min-width: 0;
}

.chat-reference-message-sender {
    font-size: 13px;
    font-weight: 600;
    color: #1a1a1a;
    margin-bottom: 4px;
}

.chat-reference-message-text {
    font-size: 13px;
    color: #6c757d;
    margin-bottom: 4px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-reference-message-time {
    font-size: 11px;
    color: #adb5bd;
}

.chat-reference-selector-footer {
    display: flex;
    gap: 12px;
    padding: 16px 24px;
    border-top: 1px solid #e9ecef;
    justify-content: flex-end;
}

.chat-reference-selector-btn {
    padding: 10px 20px;
    border-radius: 8px;
    border: none;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.chat-reference-selector-btn-cancel {
    background: #f8f9fa;
    color: #1a1a1a;
}

.chat-reference-selector-btn-cancel:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-reference-selector-btn-confirm {
    background: #007bff;
    color: #ffffff;
}

.chat-reference-selector-btn-confirm:hover {
    background: #0056b3;
}

.chat-messages,
#chatMessages {
    --kinma-chat-messages-pad-x: 16px;
    /* Hintergrund-Streifen hinter Nachrichten (Antwort blau / Referenz gelb): Wandseite voll, Verlauf nach innen */
    --kinma-chat-wall-gradient-fade: 72%;
    --kinma-chat-wall-gradient-mid: 42%;
    --kinma-chat-wall-gradient-mid-in: 58%;
    --kinma-chat-wall-gradient-fade-in: 28%;
    --kinma-chat-quote-gradient-fade: var(--chat-edge-fade, #ffffff);
}

.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded) {
    cursor: pointer;
    position: relative;
}

.chat-message-reference-mode.chat-message-reference-excluded {
    cursor: not-allowed;
    position: relative;
}

.chat-message-reference-excluded-nudge {
    animation: none !important;
}

.chat-message-reference-excluded-nudge > .chat-message-wrapper,
.chat-message-reference-excluded-nudge .chat-message-edited-below-stack > .chat-message-wrapper,
.chat-message-reference-excluded-nudge > .chat-message-outgoing-stack,
.chat-message-reference-excluded-nudge > .chat-message-incoming-stack {
    animation: kinma-reference-excluded-nudge 0.52s cubic-bezier(0.34, 1.35, 0.64, 1) both;
}

.chat-message-reference-excluded-nudge .chat-message-avatar,
.chat-message-reference-excluded-nudge .chat-message-avatar-column,
.chat-message-reference-excluded-nudge .chat-message-avatar-column--with-delivery,
.chat-message-reference-excluded-nudge .chat-message-avatar-spacer,
.chat-message-reference-excluded-nudge .chat-message-edited-below-avatar-wrap {
    transform: none !important;
    animation: none !important;
    transition: none !important;
}

@keyframes kinma-reference-excluded-nudge {
    0% { transform: translateX(0); }
    38% { transform: translateX(6px); }
    100% { transform: translateX(0); }
}

/* Nur Bubble/Zitat bewegen — Avatar-Spalte bleibt fix; Endposition immer 0 */
.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded) > .chat-message-wrapper,
.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded)
    .chat-message-edited-below-stack
    > .chat-message-wrapper {
    transform: translateX(0);
    will-change: transform;
}

.chat-message-reference-mode .chat-message-avatar,
.chat-message-reference-mode .chat-message-avatar-column,
.chat-message-reference-mode .chat-message-avatar-column--with-delivery,
.chat-message-reference-mode .chat-message-avatar-spacer,
.chat-message-reference-mode .chat-message-edited-below-avatar-wrap {
    transform: none !important;
    animation: none !important;
    transition: none !important;
}

/* Kurzer Nudge weg vom Profil und zurück (Auswahl + Abwahl) */
.chat-message-bot.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded).chat-message-reference-nudge
    > .chat-message-wrapper,
.chat-message-bot.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded).chat-message-reference-nudge
    .chat-message-edited-below-stack
    > .chat-message-wrapper {
    animation: kinma-reference-nudge-incoming 0.52s cubic-bezier(0.34, 1.35, 0.64, 1) both;
}

.chat-message-user.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded).chat-message-reference-nudge
    > .chat-message-wrapper,
.chat-message-user.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded).chat-message-reference-nudge
    .chat-message-edited-below-stack
    > .chat-message-wrapper {
    animation: kinma-reference-nudge-outgoing 0.52s cubic-bezier(0.34, 1.35, 0.64, 1) both;
}

@keyframes kinma-reference-nudge-incoming {
    0% {
        transform: translateX(0);
    }
    38% {
        transform: translateX(8px);
    }
    100% {
        transform: translateX(0);
    }
}

@keyframes kinma-reference-nudge-outgoing {
    0% {
        transform: translateX(0);
    }
    38% {
        transform: translateX(-8px);
    }
    100% {
        transform: translateX(0);
    }
}

.chat-message-reference-checkbox {
    display: none !important;
}

/* Verlauf bis zur Chat-Wand: Zeilen-padding-inline + negatives inset (siehe .chat-messages padding: 16px 0). */
.chat-message-reference-mode:not(.chat-message-reference-excluded):not(.chat-message-base-reply):not(.chat-message-reply-target-active).chat-message-reference-selected::before,
.chat-message-reference-mode:not(.chat-message-reference-excluded):not(.chat-message-base-reply):not(.chat-message-reply-target-active).chat-message-reference-highlight-out::before,
.chat-message-reference-mode:not(.chat-message-reference-excluded):not(.chat-message-base-reply):not(.chat-message-reply-target-active):hover:not(.chat-message-reference-selected)::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
    right: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
    width: auto;
    z-index: 0;
    pointer-events: none;
    border-radius: 0;
}

/* Hover-Vorschau: kein Einblend-Scale wie bei Auswahl */
.chat-message-reference-mode:not(.chat-message-reference-excluded):not(.chat-message-base-reply):not(.chat-message-reply-target-active):hover:not(.chat-message-reference-selected)::before {
    animation: none !important;
    opacity: 1;
    transform: scaleX(1);
}

.chat-message-reference-selected::before {
    animation: kinma-reference-highlight-in 0.48s cubic-bezier(0.34, 1.2, 0.64, 1) forwards;
}

.chat-message-reference-instant::before,
.chat-message-reference-selected.chat-message-reference-instant::before {
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
    transform: scaleX(1) !important;
}

.chat-message-bot.chat-message-reference-instant::before,
.chat-message-bot.chat-message-reference-selected.chat-message-reference-instant::before,
.chat-message-bot.chat-message-reference-highlight-out.chat-message-reference-instant::before {
    transform-origin: left center !important;
}

.chat-message-user.chat-message-reference-instant::before,
.chat-message-user.chat-message-reference-selected.chat-message-reference-instant::before,
.chat-message-user.chat-message-reference-highlight-out.chat-message-reference-instant::before {
    transform-origin: right center !important;
}

.chat-message-reference-highlight-out::before {
    animation: kinma-reference-highlight-out 0.4s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes kinma-reference-highlight-in {
    0% {
        opacity: 0;
        transform: scaleX(0);
    }
    100% {
        opacity: 1;
        transform: scaleX(1);
    }
}

@keyframes kinma-reference-highlight-out {
    0% {
        opacity: 1;
        transform: scaleX(1);
    }
    100% {
        opacity: 0;
        transform: scaleX(0);
    }
}

@media (prefers-reduced-motion: reduce) {
    .chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded) > .chat-message-wrapper,
    .chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded)
        .chat-message-edited-below-stack
        > .chat-message-wrapper {
        transform: none !important;
        will-change: auto;
        animation: none !important;
    }

    .chat-message-reference-selected::before,
    .chat-message-reference-highlight-out::before {
        animation: none;
        transform: none;
    }

    .chat-message-reference-selected::before {
        opacity: 1;
    }

    .chat-message-reference-highlight-out::before {
        opacity: 0;
    }
}

/* Eingehend: Verlauf rechts → links, volle Farbe an linker Wand (Faden) */
.chat-message-bot.chat-message-reference-selected::before,
.chat-message-bot.chat-message-reference-highlight-out::before {
    transform-origin: left center;
    background: linear-gradient(
        to left,
        transparent var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 38%, transparent)
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 100%
    );
}

/* Ausgehend: Verlauf rechts → links, volle Farbe an rechter Wand (Faden) */
.chat-message-user.chat-message-reference-selected::before,
.chat-message-user.chat-message-reference-highlight-out::before {
    transform-origin: right center;
    background: linear-gradient(
        to left,
        var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 0%,
        color-mix(in srgb, var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 38%, transparent)
            var(--kinma-chat-wall-gradient-mid, 42%),
        transparent var(--kinma-chat-wall-gradient-fade, 72%)
    );
}

/* Hover-Vorschau: gleiche Seite wie die Bubble, etwas schwächer als die Auswahl */
.chat-message-bot.chat-message-reference-mode:not(.chat-message-reference-excluded):hover:not(.chat-message-reference-selected)::before {
    transform-origin: left center;
    background: linear-gradient(
        to left,
        transparent var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 8%, transparent)
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        color-mix(in srgb, var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 22%, transparent) 100%
    );
}

.chat-message-user.chat-message-reference-mode:not(.chat-message-reference-excluded):not(.chat-message-base-reply):not(.chat-message-reply-target-active):hover:not(.chat-message-reference-selected)::before {
    transform-origin: right center;
    background: linear-gradient(
        to left,
        color-mix(in srgb, var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 22%, transparent) 0%,
        color-mix(in srgb, var(--kinma-chat-referenzen-bg, rgba(254, 243, 199, 0.98)) 8%, transparent)
            var(--kinma-chat-wall-gradient-mid, 42%),
        transparent var(--kinma-chat-wall-gradient-fade, 72%)
    );
}

.chat-message-reference-selected > *,
.chat-message-reference-mode:not(.chat-message-reference-excluded):not(.chat-message-base-reply):not(.chat-message-reply-target-active):hover:not(.chat-message-reference-selected) > * {
    position: relative;
    z-index: 1;
}

/* Antwort-Ziel: blauer Verlauf (Farbe der Antwort-Box) + gleicher Nudge wie bei Referenzen */
.chat-message-reply-target-active::before,
.chat-message-reply-target-highlight-out::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
    right: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
    width: auto;
    z-index: 0;
    pointer-events: none;
    border-radius: 0;
}

.chat-message-reply-target-active:not(.chat-message-reply-swipe-preview)::before {
    animation: none !important;
    opacity: 1 !important;
    transform: scaleX(1) !important;
}

.chat-message-reply-target-active.chat-message-reply-target-instant::before {
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
    transform: scaleX(1) !important;
}

.chat-message-bot.chat-message-reply-target-active.chat-message-reply-target-instant::before {
    transform-origin: left center !important;
}

.chat-message-user.chat-message-reply-target-active.chat-message-reply-target-instant::before {
    transform-origin: right center !important;
}

/* Nach Swipe-Reply: Verlauf nicht erneut einblenden (Poll/Sync/210ms-Swipe-Ende) */
.chat-message-reply-highlight-committed::before,
.chat-message-reply-target-active.chat-message-reply-highlight-committed::before {
    animation: none !important;
    transition: none !important;
    opacity: 1 !important;
    transform: scaleX(1) !important;
}

.chat-message-bot.chat-message-reply-highlight-committed::before,
.chat-message-bot.chat-message-reply-target-active.chat-message-reply-highlight-committed::before {
    transform-origin: left center !important;
}

.chat-message-user.chat-message-reply-highlight-committed::before,
.chat-message-user.chat-message-reply-target-active.chat-message-reply-highlight-committed::before {
    transform-origin: right center !important;
}

/* Mobile Swipe: blauer Verlauf folgt dem Zug (Stärke über --kinma-reply-highlight-strength) */
.chat-message-reply-swipe-preview::before {
    content: '';
    position: absolute;
    top: 0;
    bottom: 0;
    left: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
    right: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
    width: auto;
    z-index: 0;
    pointer-events: none;
    border-radius: 0;
    animation: none !important;
    opacity: var(--kinma-reply-highlight-strength, 0);
    transform: scaleX(var(--kinma-reply-highlight-strength, 0));
}

.chat-message-bot.chat-message-reply-swipe-preview::before {
    transform-origin: left center !important;
    background: linear-gradient(
        to left,
        transparent var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 35%, transparent)
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 100%
    );
}

.chat-message-user.chat-message-reply-swipe-preview::before {
    transform-origin: right center !important;
    background: linear-gradient(
        to left,
        var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 0%,
        color-mix(in srgb, var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 35%, transparent)
            var(--kinma-chat-wall-gradient-mid, 42%),
        transparent var(--kinma-chat-wall-gradient-fade, 72%)
    );
}

.chat-message-reply-target-active.chat-message-reply-swipe-preview::before,
.chat-message-reply-swipe-preview.chat-message-reply-target-active::before {
    animation: none !important;
    transition: none !important;
    opacity: var(--kinma-reply-highlight-strength, 1) !important;
    transform: scaleX(var(--kinma-reply-highlight-strength, 1)) !important;
}

.chat-message-reply-swipe-preview > * {
    position: relative;
    z-index: 1;
}

.chat-message-reply-target-highlight-out::before {
    animation: kinma-reply-target-highlight-out 0.4s cubic-bezier(0.4, 0, 0.2, 1) forwards;
}

@keyframes kinma-reply-target-highlight-in {
    0% {
        opacity: 0;
        transform: scaleX(0);
    }
    100% {
        opacity: 1;
        transform: scaleX(1);
    }
}

@keyframes kinma-reply-target-highlight-out {
    0% {
        opacity: 1;
        transform: scaleX(1);
    }
    100% {
        opacity: 0;
        transform: scaleX(0);
    }
}

.chat-message-bot.chat-message-reply-target-active::before,
.chat-message-bot.chat-message-reply-target-highlight-out::before {
    transform-origin: left center;
    background: linear-gradient(
        to left,
        transparent var(--kinma-chat-wall-gradient-fade-in, 28%),
        color-mix(in srgb, var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 35%, transparent)
            var(--kinma-chat-wall-gradient-mid-in, 58%),
        var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 100%
    );
}

.chat-message-user.chat-message-reply-target-active::before,
.chat-message-user.chat-message-reply-target-highlight-out::before {
    transform-origin: right center;
    background: linear-gradient(
        to left,
        var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 0%,
        color-mix(in srgb, var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 35%, transparent)
            var(--kinma-chat-wall-gradient-mid, 42%),
        transparent var(--kinma-chat-wall-gradient-fade, 72%)
    );
}

.chat-message-reply-target-active > .chat-message-wrapper,
.chat-message-reply-target-active .chat-message-edited-below-stack > .chat-message-wrapper {
    transform: translateX(0);
    will-change: transform;
}

.chat-message-bot.chat-message-reply-target-nudge > .chat-message-wrapper,
.chat-message-bot.chat-message-reply-target-nudge .chat-message-edited-below-stack > .chat-message-wrapper {
    animation: kinma-reference-nudge-incoming 0.52s cubic-bezier(0.34, 1.35, 0.64, 1) both;
}

.chat-message-user.chat-message-reply-target-nudge > .chat-message-wrapper,
.chat-message-user.chat-message-reply-target-nudge .chat-message-edited-below-stack > .chat-message-wrapper {
    animation: kinma-reference-nudge-outgoing 0.52s cubic-bezier(0.34, 1.35, 0.64, 1) both;
}

.chat-message-reply-target-active > *,
.chat-message-reply-target-highlight-out > * {
    position: relative;
    z-index: 1;
}

@media (prefers-reduced-motion: reduce) {
    .chat-message-reply-target-active::before,
    .chat-message-reply-target-highlight-out::before {
        animation: none;
        transform: none;
    }

    .chat-message-reply-target-active::before {
        opacity: 1;
    }

    .chat-message-reply-target-highlight-out::before {
        opacity: 0;
    }

    .chat-message-reply-target-nudge > .chat-message-wrapper,
    .chat-message-reply-target-nudge .chat-message-edited-below-stack > .chat-message-wrapper {
        animation: none !important;
    }
}

/* Referenzmodus: Klick auf Zitat-/Referenz-UI wählt die Nachricht (Capture-Handler), nicht scrollToMessage */
.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded) .chat-message-quote-above,
.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded) .chat-message-references--in-quote-stack,
.chat-message-reference-mode:not(.chat-message-base-reply):not(.chat-message-reference-excluded) .chat-message-quote-stack {
    cursor: pointer;
}

.chat-reference-search-bar {
    padding: 12px 16px;
    background: #ffffff;
    border-bottom: 1px solid #e9ecef;
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-reference-search-wrapper {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 24px;
    padding: 8px 16px;
    width: 100%;
    max-width: 500px;
    transition: all 0.2s ease;
}

.chat-reference-search-wrapper:focus-within {
    background: #ffffff;
    border-color: #007bff;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.1);
}

.chat-reference-search-wrapper svg {
    flex-shrink: 0;
    color: #6c757d;
}

.chat-reference-search-input {
    flex: 1;
    border: none;
    background: transparent;
    outline: none;
    font-size: 14px;
    color: #1a1a1a;
    min-width: 0;
}

.chat-reference-search-input::placeholder {
    color: #adb5bd;
}

.chat-reference-search-cancel {
    width: 24px;
    height: 24px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: 50%;
    cursor: pointer;
    color: #6c757d;
    transition: all 0.2s ease;
    flex-shrink: 0;
    padding: 0;
}

.chat-reference-search-cancel:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-attachment-menu {
    position: fixed;
    background: #ffffff;
    border-radius: 12px;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15), 0 0 0 1px rgba(0, 0, 0, 0.05);
    padding: 8px;
    min-width: 220px;
    /* Über Chat-Popup (bis 100004) und mobiler Bottom-Nav im Overlay (100110); JS setzt dieselbe Ebene */
    z-index: 100126;
    display: flex;
    flex-direction: column;
    gap: 4px;
    animation: contextMenuFadeIn 0.15s ease-out;
}

.chat-attachment-menu-item {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    min-height: 44px;
    box-sizing: border-box;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s ease;
    color: #1a1a1a;
    font-size: 14px;
    -webkit-tap-highlight-color: transparent;
}

.chat-attachment-menu-item:hover {
    background: #f8f9fa;
}

.chat-attachment-menu-item svg {
    flex-shrink: 0;
    color: #6c757d;
}

.chat-attachment-menu-item:hover svg {
    color: #1a1a1a;
}

.chat-attachment-menu-item span {
    flex: 1;
}

.chat-share-dialog {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10001;
    animation: fadeIn 0.2s ease-out;
}

.chat-share-dialog-content {
    background: #ffffff;
    border-radius: 12px;
    width: 90%;
    max-width: 500px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
    animation: slideUp 0.2s ease-out;
}

.chat-share-dialog-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px;
    border-bottom: 1px solid #e9ecef;
}

.chat-share-dialog-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-share-dialog-close {
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    border: none;
    background: transparent;
    border-radius: 6px;
    cursor: pointer;
    color: #6c757d;
    font-size: 24px;
    line-height: 1;
    transition: all 0.2s ease;
}

.chat-share-dialog-close:hover {
    background: #f8f9fa;
    color: #1a1a1a;
}

.chat-share-dialog-body {
    padding: 24px;
}

.chat-share-dialog-body p {
    margin: 0 0 16px 0;
    color: #1a1a1a;
    font-size: 14px;
}

.chat-share-dialog-options {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.chat-share-dialog-options label {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px;
    border-radius: 8px;
    cursor: pointer;
    transition: background 0.2s ease;
}

.chat-share-dialog-options label:hover {
    background: #f8f9fa;
}

.chat-share-dialog-options input[type="radio"] {
    width: 18px;
    height: 18px;
    cursor: pointer;
}

.chat-share-dialog-options span {
    flex: 1;
    color: #1a1a1a;
    font-size: 14px;
}

.chat-share-dialog-footer {
    display: flex;
    gap: 12px;
    padding: 16px 24px;
    border-top: 1px solid #e9ecef;
    justify-content: flex-end;
}

.chat-share-dialog-btn {
    padding: 10px 20px;
    border-radius: 8px;
    border: none;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.chat-share-dialog-btn-cancel {
    background: #f8f9fa;
    color: #1a1a1a;
}

.chat-share-dialog-btn-cancel:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-share-dialog-btn-confirm {
    background: #007bff;
    color: #ffffff;
}

.chat-share-dialog-btn-confirm:hover {
    background: #0056b3;
}

.chat-camera-dialog {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.9);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 10001;
}

.chat-camera-dialog-content {
    background: #ffffff;
    border-radius: 12px;
    width: 90%;
    max-width: 600px;
    padding: 24px;
}

.chat-camera-dialog-body {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    margin: 20px 0;
}

.chat-camera-btn {
    padding: 12px 24px;
    border-radius: 8px;
    border: none;
    font-size: 16px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.chat-camera-btn-capture {
    background: #28a745;
    color: #ffffff;
    width: 100%;
}

.chat-camera-btn-capture:hover {
    background: #218838;
}

.chat-contact-avatar-wrapper {
    position: relative;
    flex-shrink: 0;
    align-self: flex-start;
    margin-top: 1px;
    overflow: visible;
}

/* Basis-Fallback; in #chatPopup setzt chat-box-v2.css --kinma-avatar-size / --kinma-presence-dot-size */
.chat-contact-avatar {
    width: var(--kinma-avatar-size, 40px);
    height: var(--kinma-avatar-size, 40px);
    border-radius: 50%;
    background: #1a1a1a;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: calc(var(--kinma-avatar-size, 40px) * 0.32);
    flex-shrink: 0;
}

.chat-group-avatar-icon {
    width: 54%;
    height: 54%;
    display: block;
    color: currentColor;
}

.chat-contact-status {
    position: absolute;
    bottom: var(--kinma-presence-dot-offset, 0);
    right: var(--kinma-presence-dot-offset, 0);
    width: var(--kinma-presence-dot-size, 11px);
    height: var(--kinma-presence-dot-size, 11px);
    border-radius: 50%;
    border: none;
    box-sizing: border-box;
    transition: background-color 0.3s ease;
}

.chat-contact-status[data-status="green"] {
    background-color: #28a745;
}

.chat-contact-status[data-status="yellow"] {
    background-color: #ffc107;
}

.chat-contact-status[data-status="red"] {
    background-color: #dc3545;
}

.chat-contact-status[data-status="offline"],
.chat-contact-status[data-status="gray"] {
    background-color: #9ca3af;
}

/* Rohwerte aus API (falls data-status noch nicht gemappt) */
.chat-contact-status[data-status="online"] {
    background-color: #28a745;
}

.chat-contact-status[data-status="away"] {
    background-color: #ffc107;
}

.chat-contact-status[data-status="dnd"] {
    background-color: #dc3545;
}

.chat-contact-item.active .chat-contact-status[data-status="green"],
.chat-contact-item.active .chat-contact-status[data-status="online"] {
    background-color: #22c55e !important;
}

.chat-contact-item.active .chat-contact-status[data-status="yellow"],
.chat-contact-item.active .chat-contact-status[data-status="away"] {
    background-color: #facc15 !important;
}

.chat-contact-item.active .chat-contact-status[data-status="red"],
.chat-contact-item.active .chat-contact-status[data-status="dnd"] {
    background-color: #ef4444 !important;
}

.chat-contact-item.active .chat-contact-status[data-status="gray"],
.chat-contact-item.active .chat-contact-status[data-status="offline"] {
    background-color: #9ca3af !important;
}

.chat-contact-info {
    flex: 1;
    min-width: 0;
}

.chat-contact-name-wrapper {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
}

.chat-contact-name {
    font-size: 14px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    flex: 1;
    min-width: 0;
    line-height: 1.3;
}

.chat-contact-closed-badge {
    display: inline-flex;
    align-items: center;
    padding: 2px 6px;
    border-radius: 4px;
    background: #f8f9fa;
    color: #6c757d;
    font-size: 11px;
    font-weight: 500;
    text-transform: uppercase;
    letter-spacing: 0.3px;
    flex-shrink: 0;
    margin-left: 6px;
    border: 1px solid #dee2e6;
}

.chat-contact-name-wrapper:has(.chat-contact-exit-account-icon) .chat-contact-name {
    color: var(--kinma-chat-left-family-name-color, #dc2626);
}

.chat-contact-item.active .chat-contact-name-wrapper:has(.chat-contact-exit-account-icon) .chat-contact-name {
    color: var(--kinma-chat-left-family-name-color, #dc2626) !important;
    text-shadow: var(--kinma-chat-contact-active-text-shadow);
}

.chat-contact-exit-account-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    margin-left: 4px;
    color: var(--kinma-chat-left-family-name-color, #dc2626);
    background: none;
    border: none;
    box-shadow: none;
}

.chat-contact-exit-account-icon svg {
    display: block;
    width: 14px;
    height: 14px;
    flex-shrink: 0;
}

.chat-contact-preview {
    font-size: 12px;
    color: #6c757d;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-top: 1px;
    line-height: 1.3;
}
.chat-contact-preview-call {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    color: #16a34a;
    font-weight: 600;
}
.chat-contact-preview-call-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: currentColor;
    flex-shrink: 0;
    animation: chatLiveCallPulse 1.35s ease-in-out infinite;
}
.chat-contact-preview-call-text {
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.chat-contact-meta {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 3px;
    flex-shrink: 0;
    align-self: flex-start;
    padding-top: 1px;
}

.chat-contact-time {
    font-size: 11px;
    color: #6c757d;
    white-space: nowrap;
}

.chat-contact-unread {
    background: #ef4444;
    color: #ffffff;
    border-radius: 8px;
    padding: 2px 6px;
    font-size: 11px;
    font-weight: 600;
    min-width: 20px;
    text-align: center;
    flex-shrink: 0;
    line-height: 1.4;
}
.chat-contact-live-call-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 34px;
    padding: 2px 7px;
    border-radius: 999px;
    background: rgba(22, 163, 74, 0.12);
    color: #15803d;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.08em;
}
@keyframes chatLiveCallPulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.45; transform: scale(0.88); }
}

.chat-main {
    flex: 1;
    display: flex; /* Always visible when chat popup is open */
    flex-direction: column;
    background: #ffffff;
    position: relative;
}

.chat-main-header {
    display: flex;
    align-items: center;
    padding: 16px 20px;
    border-bottom: none;
    background: #ffffff;
    transition: background 0.2s ease;
    flex-shrink: 0;
}

.chat-main-header-normal {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 10px;
}

.chat-main-header-ghost-close-btn {
    width: 28px;
    height: 28px;
    border: 1px solid #e5e7eb;
    border-radius: 999px;
    background: #ffffff;
    color: #6b7280;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    flex-shrink: 0;
}

.chat-main-header-ghost-close-btn:hover {
    background: #f3f4f6;
    color: #1a1a1a;
}

.chat-main-header:hover {
    background: #f8f9fa;
}

.chat-header-activity-strip {
    display: none;
}

.chat-header-activity-pill {
    min-width: 0;
    width: 188px;
    max-width: min(68vw, 240px);
    border: none;
    border: 1px solid rgba(26, 26, 26, 0.08);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.72);
    box-shadow: none;
    padding: 0;
    display: flex;
    align-items: stretch;
    gap: 4px;
    cursor: pointer;
    flex: 0 0 auto;
    text-align: left;
    color: #1a1a1a;
    font: inherit;
    appearance: none;
    -webkit-appearance: none;
    position: relative;
    overflow: hidden;
    opacity: 0.68;
    transition: transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease, border-color 0.18s ease, filter 0.18s ease, opacity 0.18s ease;
}

.chat-header-activity-pill:hover,
.chat-header-activity-pill:focus-visible,
.chat-header-activity-pill.is-fully-visible {
    opacity: 1;
    background: #ffffff;
    box-shadow: none;
    transform: none;
    outline: none;
}

.chat-header-activity-pill--location:hover,
.chat-header-activity-pill--location:focus-visible,
.chat-header-activity-pill--location.is-fully-visible,
.chat-header-activity-pill--poll:hover,
.chat-header-activity-pill--poll:focus-visible,
.chat-header-activity-pill--poll.is-fully-visible,
.chat-header-activity-pill--poll[data-poll-state="empty"]:hover,
.chat-header-activity-pill--poll[data-poll-state="empty"]:focus-visible,
.chat-header-activity-pill--poll[data-poll-state="empty"].is-fully-visible,
.chat-header-activity-pill--poll[data-poll-state="voted"]:hover,
.chat-header-activity-pill--poll[data-poll-state="voted"]:focus-visible,
.chat-header-activity-pill--poll[data-poll-state="voted"].is-fully-visible {
    background: #ffffff;
    filter: none;
}

.chat-header-activity-pill:active {
    transform: translateY(0);
}

.chat-header-activity-pill--location {
    width: 122px;
    max-width: min(52vw, 160px);
    background: rgba(255, 255, 255, 0.72);
}

.chat-header-activity-pill--location > :not(.chat-header-activity-pill-bg-progress) {
    position: relative;
    z-index: 1;
}

.chat-header-activity-pill--poll {
    width: 230px;
    max-width: min(82vw, 286px);
    background: rgba(255, 255, 255, 0.82);
    border-color: rgba(99, 102, 241, 0.14);
    box-shadow: none;
}

.chat-header-activity-pill--poll[data-poll-state="empty"] {
    background: rgba(255, 255, 255, 0.72);
    border-color: rgba(99, 102, 241, 0.1);
    box-shadow: none;
    filter: saturate(0.82);
}

.chat-header-activity-pill--poll[data-poll-state="voted"] {
    background: rgba(255, 255, 255, 0.92);
    border-color: rgba(79, 70, 229, 0.24);
    box-shadow: none;
}

#chatMain .chat-header-activity-strip-scroll.is-scrolling .chat-header-activity-pill,
#chatMain .chat-header-activity-strip-scroll.is-dragging .chat-header-activity-pill,
#chatMain .chat-header-activity-strip-scroll.is-pointer-down .chat-header-activity-pill {
    opacity: 1;
    background: rgba(255, 255, 255, 0.96);
    filter: none;
}

#chatMain .chat-header-activity-strip-scroll.is-scrolling .chat-header-activity-pill--location,
#chatMain .chat-header-activity-strip-scroll.is-dragging .chat-header-activity-pill--location,
#chatMain .chat-header-activity-strip-scroll.is-pointer-down .chat-header-activity-pill--location {
    background: #ffffff;
}

#chatMain .chat-header-activity-strip-scroll.is-scrolling .chat-header-activity-pill--poll,
#chatMain .chat-header-activity-strip-scroll.is-dragging .chat-header-activity-pill--poll,
#chatMain .chat-header-activity-strip-scroll.is-pointer-down .chat-header-activity-pill--poll {
    background: #ffffff;
}

.chat-header-activity-pill:hover .chat-header-activity-poll-stat,
.chat-header-activity-pill:focus-visible .chat-header-activity-poll-stat,
.chat-header-activity-pill.is-fully-visible .chat-header-activity-poll-stat,
#chatMain .chat-header-activity-strip-scroll.is-scrolling .chat-header-activity-pill .chat-header-activity-poll-stat,
#chatMain .chat-header-activity-strip-scroll.is-dragging .chat-header-activity-pill .chat-header-activity-poll-stat,
#chatMain .chat-header-activity-strip-scroll.is-pointer-down .chat-header-activity-pill .chat-header-activity-poll-stat {
    background: #ffffff;
    box-shadow: none;
}

.chat-header-activity-avatar,
.chat-header-activity-icon {
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

.chat-header-activity-avatar {
    align-self: stretch;
    width: auto;
    min-width: 0;
    height: auto;
    aspect-ratio: 1 / 1;
    color: #ffffff;
    font-size: 9px;
    font-weight: 700;
}

.chat-header-activity-icon {
    width: 24px;
    height: 24px;
    min-width: 24px;
    align-self: center;
    background: #6366f1;
    color: #ffffff;
}

.chat-header-activity-pill--poll .chat-header-activity-icon {
    box-shadow: none;
}

.chat-header-activity-icon svg {
    width: 14px;
    height: 14px;
}

.chat-header-activity-body {
    min-width: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
    gap: 1px;
}

.chat-header-activity-body--location {
    gap: 0;
    flex: 0 1 auto;
}

.chat-header-activity-meta--location {
    font-size: 9px;
    font-weight: 700;
    line-height: 1;
    color: #1a1a1a;
}

.chat-header-activity-pill-bg-progress {
    position: absolute;
    inset: 0 auto 0 0;
    width: 0;
    border-radius: inherit;
    background: rgba(99, 102, 241, 0.14);
    pointer-events: none;
    z-index: 0;
}

.chat-header-activity-title-row,
.chat-header-activity-meta-row {
    display: flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
}

.chat-header-activity-title {
    min-width: 0;
    font-size: 9px;
    font-weight: 700;
    line-height: 1.05;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-header-activity-subtitle,
.chat-header-activity-meta {
    min-width: 0;
    font-size: 8px;
    line-height: 1;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-header-activity-badge {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    padding: 2px 7px;
    font-size: 9px;
    font-weight: 700;
    line-height: 1;
    background: rgba(99, 102, 241, 0.12);
    color: #4f46e5;
}

.chat-header-activity-badge--voted {
    background: rgba(16, 185, 129, 0.14);
    color: #047857;
}

.chat-header-activity-badge--muted {
    background: rgba(148, 163, 184, 0.14);
    color: #64748b;
}

.chat-header-activity-poll-stats {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 5px;
    min-width: 0;
    flex: 0 0 auto;
    margin-left: auto;
}

.chat-header-activity-poll-stat {
    min-width: 0;
    max-width: 42px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 1px;
    flex: 0 1 auto;
}

.chat-header-activity-poll-percent {
    flex: 0 0 auto;
    font-size: 9px;
    font-weight: 700;
    line-height: 1;
    white-space: nowrap;
    letter-spacing: -0.01em;
}

.chat-header-activity-poll-percent.is-leading {
    font-size: 11px;
    font-weight: 800;
}

.chat-header-activity-pill--poll .chat-header-activity-body {
    gap: 2px;
    justify-content: center;
}

.chat-header-activity-pill--poll .chat-header-activity-title-row {
    width: 100%;
    align-items: center;
    gap: 6px;
}

.chat-header-activity-poll-label {
    min-width: 0;
    max-width: 100%;
    font-size: 7px;
    line-height: 1.05;
    color: #64748b;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: right;
}

.chat-header-activity-poll-more {
    flex: 0 0 auto;
    align-self: flex-start;
    font-size: 8px;
    font-weight: 700;
    line-height: 1;
    color: #64748b;
    padding-top: 1px;
}

.chat-header-activity-subtitle--poll {
    font-size: 7px;
    font-weight: 700;
    line-height: 1;
    color: #6366f1;
    letter-spacing: 0.01em;
}

.chat-header-activity-poll-stat {
    border-radius: 12px;
    background: rgba(255, 255, 255, 0.88);
    box-shadow: none;
    padding: 1px 3px 1px;
}

.chat-header-activity-poll-stat:first-child {
    background: rgba(255, 255, 255, 0.98);
    box-shadow: none;
}

.chat-header-activity-pill--poll[data-poll-state="empty"] .chat-header-activity-title,
.chat-header-activity-pill--poll[data-poll-state="empty"] .chat-header-activity-subtitle--poll,
.chat-header-activity-pill--poll[data-poll-state="empty"] .chat-header-activity-poll-label,
.chat-header-activity-pill--poll[data-poll-state="empty"] .chat-header-activity-poll-more {
    color: #7c8798;
}

.chat-header-activity-pill--poll[data-poll-state="empty"] .chat-header-activity-poll-stat {
    background: rgba(255, 255, 255, 0.72);
    box-shadow: none;
}

.chat-header-activity-pill--poll[data-poll-state="empty"] .chat-header-activity-poll-stat:first-child {
    background: rgba(255, 255, 255, 0.82);
    box-shadow: none;
}

.chat-header-activity-progress {
    position: relative;
    width: 100%;
    height: 4px;
    border-radius: 999px;
    background: rgba(148, 163, 184, 0.2);
    overflow: hidden;
}

.chat-header-activity-progress-fill {
    position: absolute;
    inset: 0 auto 0 0;
    height: 100%;
    border-radius: inherit;
    background: linear-gradient(90deg, #22c55e 0%, #10b981 45%, #f59e0b 100%);
}

@media (max-width: 768px) {
    .chat-header-activity-pill {
        width: 180px;
        max-width: 74vw;
        padding: 0;
        border-radius: 999px;
    }

    .chat-header-activity-pill--location {
        width: 116px;
        max-width: 54vw;
    }

    .chat-header-activity-pill--poll {
        width: 214px;
        max-width: 86vw;
    }

    .chat-header-activity-avatar,
    .chat-header-activity-icon {
        width: 22px;
        height: 22px;
        min-width: 22px;
    }

    .chat-header-activity-avatar {
        width: auto;
        height: auto;
        min-width: 0;
    }
}

.chat-profile-panel {
    width: 0;
    min-width: 0;
    height: 100%;
    background: #ffffff;
    border-right: none;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    flex-shrink: 0;
}

.chat-profile-panel.active {
    width: 320px;
    min-width: 320px;
    border-right: 1px solid #e9ecef;
}

/* Profile as full view (like Chat/Calls/Stories): panel fills content area */
.chat-popup.profile-view .chat-profile-panel.active {
    flex: 1;
    width: auto;
    min-width: 320px;
    max-width: none;
}

.chat-profile-header {
    padding: 16px 20px;
    border-bottom: 1px solid #e9ecef;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 16px;
    color: #1a1a1a;
}

.chat-profile-header-title {
    display: block;
}

/* Sidebar-Profil-Panel: gleiches Design wie Overlay/Hauptprofil (nur Verteilung anders) */
.chat-profile-header {
    padding: 12px 16px;
    background: #f8f9fa;
    color: #1a1a1a;
    justify-content: center;
    border-bottom: 1px solid #e9ecef;
}

.chat-profile-header-title {
    color: #1a1a1a;
}

.chat-profile-banner {
    width: 100%;
    height: 120px;
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
}

.chat-profile-banner-outline {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    pointer-events: none;
}

.chat-profile-banner-outline svg {
    width: 100%;
    height: 100%;
    min-height: 160px;
    opacity: 1;
}

.chat-profile-banner-outline svg path {
    fill: #ffffff !important;
    stroke: #ffffff !important;
    fill-opacity: 1 !important;
    stroke-opacity: 1 !important;
}

.chat-profile-picture-wrapper {
    position: relative;
    margin-top: -44px;
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    align-self: center;
}

.chat-profile-picture-circle {
    width: 88px;
    height: 88px;
    border-radius: 50%;
    background: #1a1a1a;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 32px;
    border: 4px solid #ffffff;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    overflow: visible;
    position: relative;
}

.chat-profile-avatar-initials {
    display: block;
    line-height: 1;
}

.chat-profile-symbol-badge {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #ffffff;
    border: 2px solid #ffffff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
    overflow: hidden;
}

.chat-profile-symbol-badge img {
    width: 90%;
    height: 90%;
    object-fit: contain;
}

.chat-profile-name-block {
    text-align: center;
    padding: 0 16px 12px;
    flex-shrink: 0;
}

.chat-profile-name-block .chat-user-status-wrapper {
    justify-content: center;
}

.chat-profile-name {
    margin: 0 0 4px 0;
    font-size: 17px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-profile-name-block .chat-user-status {
    font-size: 13px;
    color: #6c757d;
}

.chat-profile-content {
    padding: 0 16px 16px;
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

/* Profile overlay inside chat: over header when clicking contact name – full area */
.chat-header-profile-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.chat-header-profile-overlay-inner {
    background: #ffffff;
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.chat-header-profile-overlay-header {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    padding: 12px 16px;
    background: transparent;
    border-bottom: none;
    color: #1a1a1a;
}

.chat-header-profile-overlay-title {
    font-weight: 600;
    font-size: 16px;
    color: #1a1a1a;
}

.chat-header-profile-overlay-close {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 5;
    width: 36px;
    height: 36px;
    border: none;
    background: rgba(0, 0, 0, 0.2);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: rgba(255, 255, 255, 0.95);
    transition: background 0.2s, color 0.2s;
}

.chat-header-profile-overlay-close:hover {
    background: rgba(0, 0, 0, 0.35);
    color: #ffffff;
}

.chat-header-profile-overlay-menu .chat-header-profile-overlay-close {
    display: none !important;
}

/* Banner wie Hauptprofil (kompakt) – Hintergrundfarbe + Länderumriss; X-Button liegt darauf */
.chat-header-profile-overlay-banner {
    width: 100%;
    height: 140px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    flex-shrink: 0;
    position: relative;
    overflow: hidden;
}

.chat-header-profile-overlay-banner-outline {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    pointer-events: none;
}

.chat-header-profile-overlay-banner-outline svg {
    width: 100%;
    height: 100%;
    min-height: 200px;
    opacity: 1;
}

.chat-header-profile-overlay-banner-outline svg path {
    fill: #ffffff !important;
    stroke: #ffffff !important;
    fill-opacity: 1 !important;
    stroke-opacity: 1 !important;
}

/* Profilbild + Symbol-Badge (Aufbau wie Profilseite, Badge am Kreis) */
.chat-header-profile-overlay-picture-wrapper {
    position: relative;
    margin-top: calc(var(--kinma-avatar-size, 88px) * -0.5);
    margin-bottom: 8px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
    align-self: center;
    overflow: visible;
}

/* Status-Dot: gleiche Kinma-Presence-Klasse wie Sidebar (siehe chat-box-v2.css) */
.chat-header-profile-overlay-avatar-status-dot {
    z-index: 5;
}

/* Größe/Rand: chat-box-v2.css (#chatPopup) */
.chat-header-profile-overlay-picture-circle {
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: #1a1a1a;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 36px;
    border: none;
    box-shadow: none;
    overflow: hidden;
    position: relative;
}

.chat-header-profile-overlay-avatar-initials {
    display: block;
    line-height: 1;
}

.chat-header-profile-overlay-symbol-badge {
    position: absolute;
    top: -4px;
    right: -4px;
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #ffffff;
    border: 2px solid #ffffff;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
    overflow: hidden;
}

.chat-header-profile-overlay-symbol-badge img {
    width: 90%;
    height: 90%;
    object-fit: contain;
}

/* Name + einheitliche Online-Anzeige */
.chat-header-profile-overlay-name-block {
    text-align: center;
    padding: 0 16px 16px;
    flex-shrink: 0;
}

.chat-header-profile-overlay-name-block .chat-user-status-wrapper {
    justify-content: center;
}

.chat-header-profile-overlay-name {
    margin: 0 0 4px 0;
    font-size: 17px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-header-profile-overlay-name-block .chat-user-status {
    font-size: 13px;
    color: #6c757d;
}

.chat-header-profile-overlay-content {
    padding: 0 16px;
    display: flex;
    flex-direction: column;
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

.chat-header-profile-overlay-section {
    width: 100%;
    text-align: left;
    margin-bottom: 24px;
}

.chat-header-profile-overlay-section-title {
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    color: #6c757d;
    margin-bottom: 12px;
}

.chat-header-profile-overlay-info-item {
    display: flex;
    flex-direction: column;
    gap: 2px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 8px;
    margin-bottom: 8px;
}

.chat-header-profile-overlay-info-item:last-child {
    border-bottom: none;
}

.chat-header-profile-overlay-info-label {
    font-size: 12px;
    color: #6c757d;
    margin-bottom: 2px;
}

.chat-header-profile-overlay-info-value {
    font-size: 14px;
    color: #1a1a1a;
    font-weight: 500;
}

/* Button ganz unten am Rand */
.chat-header-profile-overlay-footer {
    margin-top: auto;
    padding: 16px 16px 0;
    flex-shrink: 0;
    background: #ffffff;
}

.chat-header-profile-overlay-btn {
    width: 100%;
    padding: 14px 16px;
    background: #1a1a1a;
    color: #fff;
    border: none;
    border-radius: 8px 8px 0 0;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: background 0.2s;
}

.chat-header-profile-overlay-btn:hover {
    background: #1a1a1a;
}

.chat-group-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 100;
    background: #ffffff;
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.chat-group-overlay-inner {
    width: 100%;
    height: 100%;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: #ffffff;
}

.chat-group-overlay-banner {
    width: 100%;
    height: 124px;
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    position: relative;
    flex-shrink: 0;
}

.chat-group-overlay-close {
    position: absolute;
    top: 12px;
    left: 12px;
    z-index: 2;
    width: 36px;
    height: 36px;
    border: none;
    border-radius: 50%;
    background: rgba(0, 0, 0, 0.22);
    color: rgba(255, 255, 255, 0.95);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.chat-group-overlay-picture-wrapper {
    position: relative;
    margin-top: -48px;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 2;
}

.chat-group-overlay-picture-circle {
    width: 96px;
    height: 96px;
    border-radius: 50%;
    border: 4px solid #ffffff;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    display: flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-weight: 700;
    font-size: 34px;
    background: #1a1a1a;
    text-transform: uppercase;
}

.chat-group-overlay-name-block {
    text-align: center;
    padding: 0 16px 16px;
    flex-shrink: 0;
}

.chat-group-overlay-name {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
    color: #1a1a1a;
}

.chat-group-overlay-subline {
    font-size: 13px;
    color: #64748b;
    font-weight: 500;
}

.chat-group-overlay-content {
    padding: 0 16px 16px;
    flex: 1;
    overflow-y: auto;
    min-height: 0;
}

.chat-group-overlay-section {
    margin-bottom: 20px;
}

.chat-group-overlay-section-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #64748b;
    margin-bottom: 12px;
}

.chat-group-overlay-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
}

.chat-group-overlay-action-btn {
    border: none;
    border-radius: 16px;
    background: #f8fafc;
    color: #1a1a1a;
    min-height: 88px;
    padding: 14px 12px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 8px;
    cursor: pointer;
    font-weight: 600;
}

.chat-group-overlay-action-btn:hover {
    background: #eef2f7;
}

.chat-group-overlay-members {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.chat-group-overlay-member {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 14px;
    border-radius: 18px;
    background: #f8fafc;
}

.chat-group-overlay-member--clickable {
    cursor: pointer;
    border: 1px solid transparent;
    transition: background 0.15s ease, border-color 0.15s ease, box-shadow 0.15s ease;
}

.chat-group-overlay-member--clickable:hover {
    background: #eef2ff;
    border-color: rgba(99, 102, 241, 0.25);
    box-shadow: 0 4px 14px rgba(26, 26, 26, 0.06);
}

.chat-group-overlay-member--clickable:focus-visible {
    outline: 2px solid #6366f1;
    outline-offset: 2px;
}

.chat-group-overlay-member-avatar {
    width: 40px;
    height: 40px;
    min-width: 40px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #ffffff;
    font-size: 14px;
    font-weight: 700;
}

.chat-group-overlay-member-body {
    min-width: 0;
    flex: 1 1 auto;
}

.chat-group-overlay-member-name {
    font-size: 14px;
    font-weight: 600;
    color: #1a1a1a;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-group-overlay-member-status {
    font-size: 12px;
    color: #64748b;
    margin-top: 2px;
}

.chat-group-overlay-empty {
    padding: 18px 14px;
    border-radius: 18px;
    background: #f8fafc;
    color: #64748b;
    text-align: center;
}

.chat-desktop-word-search {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 10px 12px;
    margin: 8px 12px 0;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid rgba(148, 163, 184, 0.22);
    box-shadow: 0 8px 24px rgba(26, 26, 26, 0.08);
}

.chat-desktop-word-search-input {
    flex: 1 1 auto;
    min-width: 0;
    border: none;
    outline: none;
    background: transparent;
    color: #1a1a1a;
    font-size: 14px;
}

.chat-desktop-word-search-count {
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
    min-width: 34px;
    text-align: center;
}

.chat-desktop-word-search-btn {
    width: 30px;
    height: 30px;
    min-width: 30px;
    border: none;
    border-radius: 50%;
    background: transparent;
    color: #1a1a1a;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.chat-desktop-word-search-btn:hover {
    background: #f1f5f9;
}

@media (max-width: 768px) {
    .chat-group-overlay-actions {
        grid-template-columns: 1fr;
    }
}

.chat-profile-close {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: transparent;
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #6c757d;
    transition: all 0.2s ease;
}

.chat-profile-close:hover {
    background: #f8f9fa;
    color: #1a1a1a;
}

.chat-profile-content {
    flex: 1;
    overflow-y: auto;
    padding: 24px 20px;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.chat-profile-avatar-large {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    background: #1a1a1a;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 36px;
    margin-bottom: 16px;
}

.chat-profile-name {
    font-size: 24px;
    font-weight: 600;
    color: #1a1a1a;
    margin: 0 0 8px 0;
    text-align: center;
}

.chat-profile-status {
    font-size: 14px;
    color: #6c757d;
    margin-bottom: 24px;
}

.chat-profile-section {
    width: 100%;
    margin-bottom: 24px;
}

.chat-profile-section-title {
    font-size: 12px;
    font-weight: 600;
    color: #6c757d;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    margin-bottom: 12px;
}

.chat-profile-info-item {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 12px;
    background: #f8f9fa;
    border-radius: 8px;
    margin-bottom: 8px;
}

.chat-profile-info-item svg {
    color: #6c757d;
    flex-shrink: 0;
    margin-top: 2px;
}

.chat-profile-info-label {
    font-size: 12px;
    color: #6c757d;
    margin-bottom: 2px;
}

.chat-profile-info-value {
    font-size: 14px;
    color: #1a1a1a;
    font-weight: 500;
}

.chat-profile-actions {
    width: 100%;
    margin-top: auto;
}

.chat-profile-btn-primary {
    width: 100%;
    padding: 12px 16px;
    background: #1a1a1a;
    color: #ffffff;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: all 0.2s ease;
}

.chat-profile-btn-primary:hover {
    background: #1a1a1a;
    transform: translateY(-1px);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.chat-user-info {
    display: flex;
    align-items: center;
    gap: 12px;
    animation: fadeIn 0.3s ease;
    justify-content: space-between;
    width: 100%;
}

.chat-user-avatar {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: #1a1a1a;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 14px;
}

.chat-user-details {
    flex: 1;
}

.chat-user-name {
    font-size: 15px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-user-status-wrapper {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 2px;
}

/* Nur Inline-Indikatoren neben Text — nicht Avatar-Ecken (chat-box-v2.css) */
.chat-user-status-indicator:not(.chat-user-avatar-status-dot):not(.chat-header-profile-overlay-avatar-status-dot):not(.profile-picture-presence-dot) {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    transition: background-color 0.3s ease;
}

.chat-user-status-indicator[data-status="green"] {
    background-color: #28a745;
}

.chat-user-status-indicator[data-status="yellow"] {
    background-color: #ffc107;
}

.chat-user-status-indicator[data-status="red"] {
    background-color: #dc3545;
}

.chat-user-status-indicator[data-status="offline"],
.chat-user-status-indicator[data-status="gray"] {
    background-color: #9ca3af;
}

.chat-user-status {
    font-size: 12px;
    color: #6c757d;
}

#chatMain {
    --kinma-chat-reply-reserve: 0px;
}

#chatMain > .chat-messages {
    padding-bottom: calc(16px + var(--kinma-chat-reply-reserve, 0px));
    scroll-padding-bottom: calc(8px + var(--kinma-chat-reply-reserve, 0px));
}

.chat-messages {
    /* Desktop: Zeit ein-/ausklappen — gleiche Kurve für Meta-Breite, Opazität und (wo unterstützt) Bubble-Breite */
    --kinma-chat-meta-reveal-duration: 260ms;
    --kinma-chat-meta-reveal-ease: cubic-bezier(0.4, 0, 0.2, 1);
    /* 0s = sofort beim Zuklappen; bei Zeilen-Hover wird auf --kinma-chat-meta-hover-reveal-wait umgeschaltet (Desktop-@media). */
    --kinma-chat-meta-hover-reveal-wait: 0.175s;
    --kinma-chat-meta-hover-reveal-delay: 0s;
    flex: 1;
    overflow-y: auto;
    overflow-anchor: none;
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 0;
    background: #ffffff;
    transition: opacity 0.25s ease-in-out;
    position: relative;
    z-index: 1;
    isolation: isolate;
}

/*
 * Wenig Inhalt: Nachrichten unten am Composer (nicht oben kleben).
 * Bei vollem Verlauf kollabiert der Spacer — normales Hochscrollen bis zum Anfang.
 */
.chat-messages:not(.loading)::before {
    content: '';
    display: block;
    margin-top: auto;
    flex-shrink: 0;
    width: 100%;
    height: 0;
    pointer-events: none;
}

.chat-messages.loading::before,
.chat-messages:not(:has(.chat-message))::before {
    display: none;
    margin-top: 0;
}

/* Bubble-Breite (fit-content) mit width/max-width animieren (Chrome 129+ u. a.) */
@supports (interpolate-size: allow-keywords) {
    .chat-message-user .chat-message-content:has(.chat-message-content-meta),
    .chat-message-bot .chat-message-content:has(.chat-message-content-meta) {
        interpolate-size: allow-keywords;
    }
}

.chat-messages.loading {
    pointer-events: none;
    transition: none;
    opacity: 1 !important; /* style.css hatte 0.5 — zentraler Loader soll klar sichtbar sein */
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    flex: 1 1 0% !important;
    min-height: 0 !important;
}
/* Falls beim Wechsel noch alte Knoten im DOM sind: nur der zentrale Loader, keine Bubbles */
.chat-messages.loading > .chat-message,
.chat-messages.loading > .chat-date-separator,
.chat-messages.loading > .chat-conversation-start {
    display: none !important;
}
.chat-messages.loading > .chat-messages-loading-state {
    flex: 1 1 auto;
    width: 100%;
    min-height: 0;
    box-sizing: border-box;
}
.chat-messages-loading-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 24px;
    gap: 16px;
}
.chat-messages-loading-spinner {
    width: 48px;
    height: 48px;
    border: 4px solid #e5e7eb;
    border-top-color: #6366f1;
    border-radius: 50%;
    animation: chat-messages-spin 0.7s linear infinite;
}
@keyframes chat-messages-spin {
    to { transform: rotate(360deg); }
}
.chat-messages-loading-text {
    font-size: 14px;
    color: #6b7280;
}

/* Sofort-Feedback: Ladehinweis unten (wie Eingabezeile / neueste Nachrichten) */
.kinma-chat-messages-pending {
    display: flex;
    flex-direction: column;
    min-height: min(65vh, 520px);
    box-sizing: border-box;
}
.kinma-chat-messages-pending-spacer {
    flex: 1 1 auto;
    min-height: 64px;
}
.kinma-chat-messages-loading-bottom {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 14px;
    padding: 16px 16px 24px;
    color: #6b7280;
    font-size: 14px;
}
.kinma-chat-messages-loading-bottom .chat-messages-loading-spinner {
    width: 28px;
    height: 28px;
    border-width: 3px;
    flex-shrink: 0;
}

.chat-messages {
    scroll-behavior: auto;
}

/* Opening a chat: keep scroll anchored at bottom until layout is settled (no flash at top). */
.chat-messages.kinma-chat-messages-pin-bottom {
    overflow: hidden !important;
    scroll-behavior: auto !important;
}

.chat-date-separator {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 24px 0 16px 0;
    position: relative;
    width: 100%;
}

.chat-date-separator::before,
.chat-date-separator::after {
    content: '';
    flex: 1 1 auto;
    height: 1px;
    background: #1a1a1a;
    flex-basis: 0;
    max-width: 50%;
}

.chat-date-separator::before {
    margin-right: 16px;
}

.chat-date-separator::after {
    margin-left: 16px;
}

.chat-date-separator span {
    background: transparent;
    color: #1a1a1a;
    padding: 0 8px;
    border-radius: 0;
    font-size: 12px;
    font-weight: 500;
    letter-spacing: 0.3px;
    flex-shrink: 0;
    flex-grow: 0;
    white-space: nowrap;
    border: none;
}

/* Viewport-Culling: schwere Referenz-/Antwort-Bäume erst bei Sichtbarkeit hydratisieren */
.chat-message--viewport-culled {
    content-visibility: auto;
    contain-intrinsic-size: auto 72px;
}

.chat-message-quote-stack--cull-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    margin: 0 0 6px;
    padding: 8px 12px;
    border-radius: 10px;
    background: rgba(99, 102, 241, 0.06);
    border: 1px dashed rgba(99, 102, 241, 0.28);
}

.chat-message-cull-placeholder-label {
    font-size: 12px;
    font-weight: 500;
    color: #6366f1;
    text-align: center;
    line-height: 1.35;
}

body.dark-mode .chat-message-quote-stack--cull-placeholder {
    background: rgba(129, 140, 248, 0.1);
    border-color: rgba(129, 140, 248, 0.35);
}

body.dark-mode .chat-message-cull-placeholder-label {
    color: #a5b4fc;
}

/* Hinweis über der ältesten Nachricht (wenn der vollständige Verlauf geladen ist) */
.chat-conversation-start {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
    width: 100%;
    max-width: 420px;
    margin: 28px auto 32px;
    padding: 0 20px;
    box-sizing: border-box;
}

.chat-conversation-start-title {
    margin: 0;
    font-size: 22px;
    font-weight: 600;
    line-height: 1.25;
    letter-spacing: -0.02em;
    color: #1a1a1a;
}

.chat-conversation-start-subtitle {
    margin: 10px 0 0;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.45;
    color: #6c757d;
}

.chat-conversation-start-avatars {
    --kinma-cs-avatar-size: 56px;
    --kinma-cs-avatar-overlap: 20px;
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    margin: 18px 0 0;
    padding: 0;
    max-width: 100%;
}

.chat-conversation-start-avatar-slot {
    display: inline-flex;
    flex-shrink: 0;
    position: relative;
    width: var(--kinma-cs-avatar-size);
    height: var(--kinma-cs-avatar-size);
}

.chat-conversation-start-avatar-slot + .chat-conversation-start-avatar-slot {
    margin-left: calc(-1 * var(--kinma-cs-avatar-overlap));
}

.chat-conversation-start-avatar-slot .chat-message-avatar.chat-conversation-start-avatar {
    width: var(--kinma-cs-avatar-size) !important;
    height: var(--kinma-cs-avatar-size) !important;
    min-width: var(--kinma-cs-avatar-size) !important;
    max-width: var(--kinma-cs-avatar-size) !important;
    min-height: var(--kinma-cs-avatar-size) !important;
    max-height: var(--kinma-cs-avatar-size) !important;
    aspect-ratio: 1;
    flex-shrink: 0;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-size: 18px !important;
    line-height: 1 !important;
    border-radius: 50% !important;
    border: none !important;
    box-shadow: none !important;
    box-sizing: border-box !important;
    overflow: hidden;
    position: relative;
}

/* Unteres Bild: Kreisausschnitt dort, wo das darüberliegende Avatar überlappt (statt weißer Outline) */
.chat-conversation-start-avatar-slot:not(:last-child) .chat-message-avatar.chat-conversation-start-avatar {
    -webkit-mask-image:
        radial-gradient(
            circle calc(var(--kinma-cs-avatar-size) * 0.5) at
                calc(var(--kinma-cs-avatar-size) * 0.5) calc(var(--kinma-cs-avatar-size) * 0.5),
            #000 99.5%,
            transparent 100%
        ),
        radial-gradient(
            circle calc(var(--kinma-cs-avatar-size) * 0.5) at
                calc(
                    var(--kinma-cs-avatar-size) - var(--kinma-cs-avatar-overlap) +
                        var(--kinma-cs-avatar-size) * 0.5
                )
                calc(var(--kinma-cs-avatar-size) * 0.5),
            #000 99.5%,
            transparent 100%
        );
    mask-image:
        radial-gradient(
            circle calc(var(--kinma-cs-avatar-size) * 0.5) at
                calc(var(--kinma-cs-avatar-size) * 0.5) calc(var(--kinma-cs-avatar-size) * 0.5),
            #000 99.5%,
            transparent 100%
        ),
        radial-gradient(
            circle calc(var(--kinma-cs-avatar-size) * 0.5) at
                calc(
                    var(--kinma-cs-avatar-size) - var(--kinma-cs-avatar-overlap) +
                        var(--kinma-cs-avatar-size) * 0.5
                )
                calc(var(--kinma-cs-avatar-size) * 0.5),
            #000 99.5%,
            transparent 100%
        );
    -webkit-mask-composite: source-out;
    mask-composite: subtract;
}

.chat-conversation-start-avatar-slot .chat-message-avatar.chat-conversation-start-avatar .chat-message-avatar-img {
    position: absolute;
    inset: 0;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    border-radius: 50% !important;
}

.chat-conversation-start-avatar-slot .chat-message-avatar.chat-conversation-start-avatar .chat-message-avatar-initials {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
}

.chat-conversation-start-avatar-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--kinma-cs-avatar-size);
    height: var(--kinma-cs-avatar-size);
    min-width: var(--kinma-cs-avatar-size);
    min-height: var(--kinma-cs-avatar-size);
    border-radius: 50%;
    border: none;
    box-sizing: border-box;
    background: #5c6370;
    color: #ffffff;
    font-size: 15px;
    font-weight: 600;
    line-height: 1;
    letter-spacing: -0.02em;
    box-shadow: none;
}

body.dark-mode .chat-conversation-start-title {
    color: rgba(255, 255, 255, 0.92);
}

body.dark-mode .chat-conversation-start-subtitle {
    color: rgba(255, 255, 255, 0.55);
}

body.dark-mode .chat-conversation-start-avatar-more {
    background: #4b5563;
}

@media (max-width: 768px) {
    .chat-conversation-start {
        margin-top: 20px;
        margin-bottom: 24px;
        padding: 0 16px;
    }

    .chat-conversation-start-title {
        font-size: 20px;
    }

    .chat-conversation-start-subtitle {
        font-size: 13px;
    }
}

/* Erste ungelesene eingehende Nachricht: rote Linie mit „Neu“, bleibt bis Verlassen des Verlaufs */
.chat-new-unread-divider {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    margin: 20px 0 12px 0;
    gap: 12px;
}

.chat-new-unread-divider-line {
    flex: 1 1 0;
    min-width: 0;
    height: 2px;
    background: #ef4444;
    border-radius: 1px;
}

.chat-new-unread-divider-label {
    flex-shrink: 0;
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #ef4444;
}

/* Dezenter Rot-Verlauf unter der „Neu“-Linie bis zum unteren Verlaufsrand */
#chatMessages.has-new-unread-gradient::before,
.chat-messages.has-new-unread-gradient::before {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    top: var(--kinma-new-unread-gradient-top, 0);
    bottom: 0;
    pointer-events: none;
    z-index: 0;
    background: linear-gradient(
        180deg,
        rgba(239, 68, 68, 0.1) 0%,
        rgba(239, 68, 68, 0.042) 30%,
        rgba(239, 68, 68, 0.014) 58%,
        transparent 100%
    );
}

body.dark-mode #chatMessages.has-new-unread-gradient::before,
body.dark-mode .chat-messages.has-new-unread-gradient::before,
[data-theme='dark'] #chatMessages.has-new-unread-gradient::before,
[data-theme='dark'] .chat-messages.has-new-unread-gradient::before {
    background: linear-gradient(
        180deg,
        rgba(248, 113, 113, 0.12) 0%,
        rgba(239, 68, 68, 0.048) 30%,
        rgba(239, 68, 68, 0.016) 58%,
        transparent 100%
    );
}

.chat-new-messages-bar {
    position: sticky;
    top: 12px;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 12px auto;
    width: fit-content;
    background: #ffffff;
    color: #6366f1;
    padding: 8px 16px;
    border-radius: 20px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    transition: all 0.2s ease;
    border: 1px solid #e5e7eb;
}

/* Pfeil links: zum Nach-unten-Scrollen wenn hochgescrollt – vollständig rund, nicht gestreckt */
.chat-new-messages-bar.chat-scroll-to-bottom {
    margin: 0 0 12px 12px;
    left: 0;
    width: 40px;
    height: 40px;
    min-width: 40px;
    min-height: 40px;
    max-width: 40px;
    max-height: 40px;
    padding: 0;
    border-radius: 50%;
    flex-shrink: 0;
    align-self: flex-start;
    box-sizing: border-box;
}

.chat-scroll-to-bottom-arrow {
    font-size: 20px;
    line-height: 1;
}

.chat-new-messages-bar:hover {
    background: #f3f4f6;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    transform: translateY(-1px);
}

.chat-new-messages-bar:active {
    transform: translateY(0);
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.chat-empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    height: 100%;
    color: #6c757d;
    text-align: center;
}

.chat-empty-state svg {
    color: #dee2e6;
    margin-bottom: 16px;
}

.chat-empty-state h3 {
    margin: 12px 0 8px 0;
    color: #1a1a1a;
    font-size: 18px;
    font-weight: 600;
}

.chat-empty-state p {
    font-size: 14px;
    margin: 0;
}

.chat-new-messages-empty svg {
    color: #dee2e6;
    margin-bottom: 16px;
}

.chat-new-messages-empty p {
    font-size: 14px;
    margin: 0;
}

/* Andere Person tippt: kleine runde Bubble links mit 3 Punkten */
.chat-other-typing-bubble {
    display: flex;
    align-items: center;
    justify-content: center;
    align-self: flex-start;
    margin: 6px 0 6px 12px;
    padding: 10px 16px;
    background: #e9ecef;
    border-radius: 9999px;
    box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.chat-other-typing-dots {
    display: flex;
    gap: 4px;
    align-items: center;
}

.chat-other-typing-dots span {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #6c757d;
    animation: chatTypingDot 1.2s infinite ease-in-out;
}

.chat-other-typing-dots span:nth-child(1) { animation-delay: -0.24s; }
.chat-other-typing-dots span:nth-child(2) { animation-delay: -0.12s; }
.chat-other-typing-dots span:nth-child(3) { animation-delay: 0s; }

@keyframes chatTypingDot {
    0%, 70%, 100% { transform: scale(0.85); opacity: 0.5; }
    35% { transform: scale(1); opacity: 1; }
}

/* Kontaktliste: "schreibt..." mit animierten Punkten */
.chat-contact-preview-typing {
    display: inline-flex;
    align-items: center;
    gap: 2px;
}
.chat-contact-typing-text {
    flex-shrink: 0;
}
.chat-contact-typing-dots {
    display: inline-flex;
    gap: 2px;
    align-items: center;
}
.chat-contact-typing-dots span {
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: currentColor;
    animation: chatTypingDot 1.2s infinite ease-in-out;
}
.chat-contact-typing-dots span:nth-child(1) { animation-delay: -0.24s; }
.chat-contact-typing-dots span:nth-child(2) { animation-delay: -0.12s; }
.chat-contact-typing-dots span:nth-child(3) { animation-delay: 0s; }

.chat-new-messages-list::-webkit-scrollbar {
    width: 3px !important;
    background: transparent !important;
}

.chat-messages::-webkit-scrollbar,
#chatMessages::-webkit-scrollbar {
    width: 3px !important;
    background: transparent !important;
}

.chat-messages::-webkit-scrollbar-track,
.chat-messages::-webkit-scrollbar-track-piece,
#chatMessages::-webkit-scrollbar-track,
#chatMessages::-webkit-scrollbar-track-piece {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
}

.chat-messages::-webkit-scrollbar-thumb,
#chatMessages::-webkit-scrollbar-thumb {
    background: #282a2e !important;
    border: none !important;
    border-radius: 999px !important;
    box-shadow: none !important;
}

.chat-messages::-webkit-scrollbar-thumb:hover,
#chatMessages::-webkit-scrollbar-thumb:hover {
    background: #282a2e !important;
}

.chat-messages::-webkit-scrollbar-corner,
#chatMessages::-webkit-scrollbar-corner {
    background: transparent !important;
}

.chat-contacts-list::-webkit-scrollbar {
    width: 3px !important;
    background: transparent !important;
}

.chat-contacts-list::-webkit-scrollbar-track,
.chat-contacts-list::-webkit-scrollbar-track-piece {
    background: transparent !important;
    border: none !important;
}

.chat-contacts-list::-webkit-scrollbar-thumb {
    background: #282a2e !important;
    border: none !important;
    border-radius: 999px !important;
}

.chat-contacts-list::-webkit-scrollbar-thumb:hover {
    background: #282a2e !important;
}

/* KI-Modus: Scrollbars in Chat-Popup (Nachrichten, Listen, Einstellungen — nicht Tab-Zeile: die bleibt ohne sichtbaren Balken, siehe .chat-popup-header-tabs-scroll)
 * !important: scrollbars.css setzt *::-webkit-scrollbar* / * { scrollbar-color } mit !important — sonst bleibt das Handle dunkelgrau. */
.chat-popup.ai-mode .chat-messages,
.chat-popup.ai-mode .chat-contacts-list,
.chat-popup.ai-mode #aiConversationsList,
.chat-popup.ai-mode .ai-conversations-list,
.chat-popup.ai-mode .chat-settings-panel-content,
.chat-popup.ai-mode .chat-new-messages-list,
.chat-popup.ai-mode .chat-file-preview-list,
.chat-popup.ai-mode .chat-filter-content,
.chat-popup.ai-mode textarea.chat-input {
    scrollbar-width: thin !important;
    scrollbar-color: #818cf8 transparent !important;
}

.chat-popup.ai-mode .chat-messages::-webkit-scrollbar,
.chat-popup.ai-mode .chat-contacts-list::-webkit-scrollbar,
.chat-popup.ai-mode #aiConversationsList::-webkit-scrollbar,
.chat-popup.ai-mode .ai-conversations-list::-webkit-scrollbar,
.chat-popup.ai-mode .chat-settings-panel-content::-webkit-scrollbar,
.chat-popup.ai-mode .chat-new-messages-list::-webkit-scrollbar,
.chat-popup.ai-mode .chat-file-preview-list::-webkit-scrollbar,
.chat-popup.ai-mode .chat-filter-content::-webkit-scrollbar,
.chat-popup.ai-mode textarea.chat-input::-webkit-scrollbar {
    width: 6px !important;
    height: 6px !important;
}

.chat-popup.ai-mode .chat-messages::-webkit-scrollbar-track,
.chat-popup.ai-mode .chat-contacts-list::-webkit-scrollbar-track,
.chat-popup.ai-mode #aiConversationsList::-webkit-scrollbar-track,
.chat-popup.ai-mode .ai-conversations-list::-webkit-scrollbar-track,
.chat-popup.ai-mode .chat-settings-panel-content::-webkit-scrollbar-track,
.chat-popup.ai-mode .chat-new-messages-list::-webkit-scrollbar-track,
.chat-popup.ai-mode .chat-file-preview-list::-webkit-scrollbar-track,
.chat-popup.ai-mode .chat-filter-content::-webkit-scrollbar-track,
.chat-popup.ai-mode textarea.chat-input::-webkit-scrollbar-track {
    background: transparent !important;
    border-radius: 3px !important;
}

.chat-popup.ai-mode .chat-messages::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .chat-contacts-list::-webkit-scrollbar-thumb,
.chat-popup.ai-mode #aiConversationsList::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .ai-conversations-list::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .chat-settings-panel-content::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .chat-new-messages-list::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .chat-file-preview-list::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .chat-filter-content::-webkit-scrollbar-thumb,
.chat-popup.ai-mode textarea.chat-input::-webkit-scrollbar-thumb {
    background: linear-gradient(180deg, #818cf8 0%, #6366f1 55%, #4f46e5 100%) !important;
    border-radius: 3px !important;
}

.chat-popup.ai-mode .chat-messages::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode .chat-contacts-list::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode #aiConversationsList::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode .ai-conversations-list::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode .chat-settings-panel-content::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode .chat-new-messages-list::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode .chat-file-preview-list::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode .chat-filter-content::-webkit-scrollbar-thumb:hover,
.chat-popup.ai-mode textarea.chat-input::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(180deg, #a5b4fc 0%, #6366f1 50%, #4338ca 100%) !important;
}

/* Tab-Zeile: horizontal scrollen (Mausrad/Drag), aber kein Scrollbar-Handle — auch in KI-Modus nicht wieder einblenden */
.chat-popup.ai-mode .chat-popup-header-tabs-scroll {
    scrollbar-width: none !important;
    -ms-overflow-style: none !important;
    scrollbar-color: transparent transparent !important;
}

.chat-popup.ai-mode .chat-popup-header-tabs-scroll::-webkit-scrollbar {
    display: none !important;
    width: 0 !important;
    height: 0 !important;
    background: transparent !important;
}

.chat-popup.ai-mode .chat-popup-header-tabs-scroll::-webkit-scrollbar-thumb,
.chat-popup.ai-mode .chat-popup-header-tabs-scroll::-webkit-scrollbar-track,
.chat-popup.ai-mode .chat-popup-header-tabs-scroll::-webkit-scrollbar-corner {
    background: transparent !important;
    border: 0 !important;
}

.chat-message {
    display: flex;
    gap: 10px;
    max-width: 75%;
    /* Eingehend / Ausgehend: Zeile am unteren Rand der Bubble ausrichten (Avatar unten wie WhatsApp/iMessage). */
    align-items: flex-start;
    position: relative;
    z-index: 0;
    margin-bottom: 0;
    -webkit-touch-callout: none;
    touch-action: manipulation;
}

.chat-message-grouped {
    margin-top: 0;
}

.chat-message-bot.chat-message-grouped {
    margin-top: 0;
    margin-bottom: 0px;
    margin-right: auto;
    margin-left: 0;
}

.chat-message-user.chat-message-grouped {
    margin-top: 0;
    margin-bottom: 0px;
    margin-left: auto;
    margin-right: 0;
}

.chat-message-grouped .chat-message-content {
    margin-top: 0;
    margin-bottom: 0;
}

.chat-message-avatar-spacer {
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    flex-shrink: 0;
    /* Invisible spacer to maintain exact same alignment as avatar */
    visibility: hidden;
    pointer-events: none;
}

.chat-message-edit-btn-spacer {
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    flex-shrink: 0;
    /* Invisible spacer to maintain alignment for edit button */
    visibility: hidden;
    pointer-events: none;
}

.chat-message-user .chat-message-avatar-spacer {
    order: 2;
    align-self: flex-end;
}

.chat-message-user .chat-message-edit-btn-spacer {
    order: 0;
}

.chat-message-bot {
    align-self: flex-start;
    flex-direction: row;
    margin-right: auto;
    margin-left: 0;
    align-items: flex-end;
}

.chat-message-user {
    align-self: flex-end;
    align-items: flex-end;
    flex-direction: row;
    margin-left: auto;
    margin-right: 0;
}

/*
 * Haupt-Chat (#chatMessages): Zeile = volle Listenbreite (Layout).
 * Meta-/Hover-Effekte nutzen :has(.chat-message-content:hover), nicht Zeilen-:hover — Avatar,
 * Zitat über der Bubble, KI-Aktion unter der Bubble triggern keinen Bubble-Hover.
 * Sichtbare Bubble bleibt über .chat-message-wrapper (bzw. edited-below-Stack) auf 75% begrenzt.
 */
#chatMessages {
    /* Antwort = Blau | Referenzen = warm | Rechts = Lila | Links = #212121 (Bubble = Faden) */
    --kinma-chat-quote-gradient-fade: var(--chat-edge-fade, #ffffff);
    --kinma-chat-reply-bg: rgba(147, 197, 253, 0.92);
    /* Zeilen-Highlight beim Antworten: hell wie Composer (#eaf3ff), nicht volle Bubble-Sättigung */
    --kinma-chat-reply-highlight-bg: rgba(214, 231, 255, 0.96);
    --kinma-chat-referenzen-bg: rgba(254, 243, 199, 0.98);
    --kinma-chat-referenzen-bg-hover: rgba(245, 158, 11, 0.14);
    --kinma-chat-referenzen-bg-hover-filled: #fde9a8;
    --kinma-outgoing-bubble-bg: #d4cff5;
    --kinma-outgoing-reply-thread-line: #d4cff5;
    --kinma-incoming-bubble-bg: #212121;
    --kinma-incoming-reply-thread-line: #212121;
    /* Antwort/Referenzen-Karten: feste Radien (kein 999px — sonst riesige Bögen bei Höhe) */
    --kinma-quote-card-r: 20px;
    --kinma-quote-card-r-expanded: 16px;
    --kinma-quote-card-r-row: 12px;
    /* Zwei Reply-Zeilen im 5-Min-Cluster: Abstand „Antwort auf“ zur Bubble darüber; Faden ::before koppelt mit calc daran. */
    --kinma-reply-cluster-chain-gap: 18px;
    /* Nur den Zeilenabstand überbrücken — kein zusätzliches Stück in die Nachricht darüber */
    --kinma-reply-cluster-chain-bridge: 0px;
}

#chatMessages > .chat-message {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* Seitenabstand auf Zeilen statt .chat-messages — ::before-Verläufe dürfen bis zur Wand (overflow-x clip). */
.chat-messages > .chat-message,
#chatMessages > .chat-message,
.chat-messages > .chat-date-separator,
#chatMessages > .chat-date-separator,
.chat-messages > .chat-new-unread-divider,
#chatMessages > .chat-new-unread-divider,
.chat-messages > .chat-conversation-start,
#chatMessages > .chat-conversation-start {
    padding-inline: var(--kinma-chat-messages-pad-x, 16px);
}

#chatMessages > .chat-message.chat-message-user {
    justify-content: flex-end;
}

#chatMessages > .chat-message.chat-message-bot {
    justify-content: flex-start;
}

#chatMessages > .chat-message > .chat-message-wrapper,
#chatMessages > .chat-message > .chat-message-edited-below-stack {
    max-width: 75%;
    min-width: 0;
}

/* Unsichtbarer Avatar-/Stift-Spacer soll Hover nicht „durchreichen“ (sonst trifft #chatMessages, nicht die Zeile). */
#chatMessages .chat-message-avatar-spacer,
#chatMessages .chat-message-edit-btn-spacer {
    pointer-events: auto;
}

/* Noch nicht bestätigte eigene Nachricht: Bubble leicht transparent, Overlay selbst bleibt voll sichtbar */
.chat-message.chat-message--pending-ghost .chat-message-content,
.chat-message[data-chat-pending-ghost="1"] .chat-message-content,
.chat-message.chat-message--pending-ghost .chat-message-content-meta,
.chat-message[data-chat-pending-ghost="1"] .chat-message-content-meta {
    opacity: 0.72;
    transition: opacity 0.25s ease;
}

.chat-message-pending-overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
    z-index: 3;
}

.chat-message-pending-dots {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.chat-message-pending-dots span {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: #4b5563;
    display: block;
    animation: chatPendingDotPulse 1.15s ease-in-out infinite;
}

.chat-message-pending-dots span:nth-child(2) {
    animation-delay: 0.16s;
}

.chat-message-pending-dots span:nth-child(3) {
    animation-delay: 0.32s;
}

@keyframes chatPendingDotPulse {
    0%,
    80%,
    100% {
        opacity: 0.35;
        transform: translateY(0) scale(0.9);
    }
    40% {
        opacity: 1;
        transform: translateY(-1px) scale(1);
    }
}

body.dark-mode .chat-message-pending-dots {
    background: transparent;
}

body.dark-mode .chat-message-pending-dots span {
    background: #4b5563;
}

.chat-message-user .chat-message-avatar {
    order: 2;
    align-self: flex-end;
}

.chat-message-bot .chat-message-avatar {
    align-self: flex-end;
}

.chat-message-user .chat-message-wrapper {
    order: 1;
}

.chat-message-user .chat-message-edit-btn {
    order: 0;
}

.chat-message-avatar {
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    border-radius: 50%;
    background: #1a1a1a;
    color: #ffffff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    font-size: 10px;
    flex-shrink: 0;
    box-sizing: border-box;
    min-width: var(--chat-message-line-avatar-size, 30px);
    min-height: var(--chat-message-line-avatar-size, 30px);
    max-width: var(--chat-message-line-avatar-size, 30px);
    max-height: var(--chat-message-line-avatar-size, 30px);
    background-size: cover;
    background-position: center;
    overflow: hidden;
}

.chat-message-avatar--interactive {
    cursor: pointer;
    -webkit-tap-highlight-color: transparent;
    transition: transform 0.15s ease, box-shadow 0.15s ease;
}

@media (hover: hover) and (pointer: fine) {
    .chat-message-avatar--interactive:hover {
        transform: scale(1.06);
        box-shadow: 0 2px 8px rgba(26, 26, 26, 0.2);
    }
}

.chat-message-avatar--interactive:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

/* Avatar + Stift „bearbeitet“ (Ecken-Badge) */
.chat-message-avatar-column {
    position: relative;
    width: var(--chat-message-line-avatar-size, 30px);
    flex-shrink: 0;
    align-self: flex-start;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.chat-message-user .chat-message-avatar-column {
    order: 2;
    align-self: flex-end;
}

.chat-message-bot .chat-message-avatar-column {
    align-self: flex-end;
}

/* Zustell-Häkchen außerhalb der Bubble (kein eigener Hintergrund/Schatten) */
.chat-message-user .chat-message-avatar-column--with-delivery {
    position: relative;
}

/* Mit sichtbarem Avatar: Spalte = nur Kreis-Höhe; Häkchen absolut darüber (sonst wächst die Zeile → Lücke im Cluster) */
.chat-message-user .chat-message-avatar-column--with-delivery.chat-message-delivery-anchor--on-avatar {
    align-self: flex-end;
    overflow: visible;
    position: relative;
    flex-direction: column;
    justify-content: flex-end;
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    min-height: var(--chat-message-line-avatar-size, 30px);
    max-height: var(--chat-message-line-avatar-size, 30px);
    gap: 0;
}

.chat-message-delivery-anchor--on-avatar .chat-message-delivery-aside-slot {
    position: absolute;
    left: 50%;
    right: auto;
    top: auto;
    bottom: calc(100% + 3px);
    margin: 0;
    transform: translateX(-50%);
    z-index: 1;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}

/* Gruppiert (nur Platzhalter): unten bündig mit Bubble, Häkchen am unteren Rand der Spalte */
.chat-message-user .chat-message-avatar-column--with-delivery.chat-message-delivery-anchor--spacer {
    align-self: flex-end;
    overflow: visible;
}

.chat-message-delivery-anchor--spacer .chat-message-delivery-aside-slot {
    position: absolute;
    left: 50%;
    right: auto;
    top: auto;
    bottom: 2px;
    transform: translateX(-50%);
    z-index: 1;
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-message-delivery-aside {
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 0;
    padding: 0;
    margin: 0;
    background: transparent;
    border: none;
    box-shadow: none;
    border-radius: 0;
    pointer-events: auto;
}

.chat-message-delivery-aside .chat-message-delivery-status {
    color: #94a3b8;
}

.chat-message-delivery-aside .chat-message-delivery-status--read {
    color: #38bdf8;
}

body.dark-mode .chat-message-delivery-aside {
    background: transparent;
    box-shadow: none;
}

body.dark-mode .chat-message-delivery-aside .chat-message-delivery-status {
    color: #94a3b8;
}

body.dark-mode .chat-message-delivery-aside .chat-message-delivery-status--read {
    color: #7dd3fc;
}

/* Bearbeitet: nur Stift, in Avatar-Spalte (bei Gruppierung = volle Slot-Fläche) */
.chat-message-edited-pencil {
    -webkit-tap-highlight-color: transparent;
    padding: 0;
    margin: 0;
    border: none;
    cursor: pointer;
    color: #64748b;
    background: transparent;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    align-self: center;
    border-radius: 50%;
    transition: background 0.15s ease, color 0.15s ease, box-shadow 0.15s ease;
}

.chat-message-edited-pencil-icon {
    display: block;
    pointer-events: none;
}

.chat-message-edited-pencil--slot {
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    min-width: var(--chat-message-line-avatar-size, 30px);
    min-height: var(--chat-message-line-avatar-size, 30px);
}

.chat-message-user .chat-message-edited-pencil--slot {
    order: 2;
}

/* Bearbeitet unter der Bubble (letzte / einzige im 5-Min-Cluster mit Avatar) */
.chat-message-edited-pencil--below {
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    min-width: var(--chat-message-line-avatar-size, 30px);
    min-height: var(--chat-message-line-avatar-size, 30px);
    margin-top: 6px;
    align-self: flex-end;
}

.chat-message-bot .chat-message-edited-pencil--below {
    align-self: flex-end;
}

/* Bearbeitet-Stift unter Bubble: Grid — Avatar nur Zeile 1 neben Bubble, Stift nur unter Bubble (nicht unter Avatar) */
.chat-message-edited-below-stack {
    display: grid;
    flex: 0 1 auto;
    min-width: 0;
    max-width: 100%;
    column-gap: 6px;
    row-gap: 0;
    align-items: start;
}

/* Grid-Platzierung ignorieren ggf. flex order von .chat-message-user */
.chat-message-edited-below-stack > .chat-message-wrapper,
.chat-message-edited-below-stack > .chat-message-avatar,
.chat-message-edited-below-stack > .chat-message-edited-below-avatar-wrap,
.chat-message-edited-below-stack > .chat-message-edited-pencil--below {
    order: 0;
}

.chat-message-user .chat-message-edited-below-stack {
    grid-template-columns: minmax(0, max-content) auto;
    grid-template-rows: auto auto;
    grid-template-areas:
        "bubble avatar"
        "pencil .";
    justify-items: stretch;
    column-gap: 3px;
}

.chat-message-user .chat-message-edited-below-stack > .chat-message-wrapper {
    grid-area: bubble;
    justify-self: end;
    min-width: 0;
}

.chat-message-user .chat-message-edited-below-stack > .chat-message-avatar,
.chat-message-user .chat-message-edited-below-stack > .chat-message-edited-below-avatar-wrap {
    grid-area: avatar;
    align-self: end;
}

.chat-message-edited-below-avatar-wrap {
    position: relative;
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    flex-shrink: 0;
}

.chat-message-edited-below-avatar-wrap.chat-message-delivery-anchor--on-avatar {
    height: var(--chat-message-line-avatar-size, 30px);
    min-height: var(--chat-message-line-avatar-size, 30px);
    max-height: var(--chat-message-line-avatar-size, 30px);
    display: block;
    overflow: visible;
}

.chat-message-edited-below-avatar-wrap.chat-message-delivery-anchor--on-avatar .chat-message-delivery-aside-slot {
    position: absolute;
    left: 50%;
    right: auto;
    top: auto;
    bottom: calc(100% + 3px);
    transform: translateX(-50%);
    margin: 0;
    z-index: 1;
}

.chat-message-user .chat-message-edited-below-stack > .chat-message-edited-pencil--below {
    grid-area: pencil;
    justify-self: end;
    align-self: end;
}

.chat-message-bot .chat-message-edited-below-stack {
    grid-template-columns: auto minmax(0, max-content);
    grid-template-rows: auto auto;
    grid-template-areas:
        "avatar bubble"
        ". pencil";
    justify-items: stretch;
}

.chat-message-bot .chat-message-edited-below-stack > .chat-message-avatar {
    grid-area: avatar;
    align-self: end;
}

.chat-message-bot .chat-message-edited-below-stack > .chat-message-wrapper {
    grid-area: bubble;
    justify-self: start;
    min-width: 0;
}

.chat-message-bot .chat-message-edited-below-stack > .chat-message-edited-pencil--below {
    grid-area: pencil;
    justify-self: start;
    align-self: end;
}

.chat-message-edited-pencil--on-avatar {
    position: absolute;
    width: 20px;
    height: 20px;
    min-width: 20px;
    min-height: 20px;
    bottom: -2px;
    background: rgba(255, 255, 255, 0.96);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.12);
    z-index: 1;
}

.chat-message-bot .chat-message-edited-pencil--on-avatar {
    left: -2px;
}

.chat-message-user .chat-message-edited-pencil--on-avatar {
    right: -2px;
}

/* Desktop: dezentes Hover-Highlight (kein :hover auf Touch-Geräten) */
@media (hover: hover) and (pointer: fine) {
    .chat-message-edited-pencil:hover {
        background: rgba(26, 26, 26, 0.08);
        color: #1a1a1a;
    }

    .chat-message-edited-pencil--on-avatar:hover {
        background: #f1f5f9;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.14);
    }
}

.chat-message-edited-pencil:focus-visible {
    outline: 2px solid #3b82f6;
    outline-offset: 2px;
}

body.dark-mode .chat-message-edited-pencil {
    color: #94a3b8;
}

body.dark-mode .chat-message-edited-pencil--on-avatar {
    background: rgba(26, 26, 26, 0.96);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.45);
}

@media (hover: hover) and (pointer: fine) {
    body.dark-mode .chat-message-edited-pencil:hover {
        background: rgba(255, 255, 255, 0.08);
        color: #e2e8f0;
    }

    body.dark-mode .chat-message-edited-pencil--on-avatar:hover {
        background: #1a1a1a;
        box-shadow: 0 2px 8px rgba(0, 0, 0, 0.35);
    }
}

.chat-message-wrapper {
    display: flex;
    flex-direction: column;
    gap: 0;
    max-width: 100%;
    flex: 0 1 auto;
    /* Zeit-Badge relativ zur Bubble, nicht zur ganzen Zeile (Avatar / Stift) */
    position: relative;
}

.chat-message-bot .chat-message-wrapper {
    align-items: flex-start;
}

.chat-message-user .chat-message-wrapper {
    align-items: flex-end;
}

.chat-message-bot.chat-message-grouped .chat-message-wrapper {
    align-items: flex-start;
}

.chat-message-user.chat-message-grouped .chat-message-wrapper {
    align-items: flex-end;
}

.chat-message {
    gap: 6px;
    margin-top: 0;
    margin-bottom: 0;
    --chat-swipe-progress: 0;
}

/* Outgoing: bubble sits closer to the profile picture than the default row gap */
.chat-message.chat-message-user {
    gap: 3px;
}

.chat-message.chat-message-bot {
    gap: 3px;
}

@media (max-width: 1024px) {
    .chat-messages,
    #chatMessages {
        touch-action: pan-y pinch-zoom;
        overscroll-behavior-y: contain;
        overscroll-behavior-x: none;
    }

    .chat-popup.active.chat-popup-mobile-fullscreen #chatMain,
    .chat-popup.active.chat-popup-mobile-fullscreen #chatMain .chat-messages,
    .chat-popup.active.chat-popup-mobile-fullscreen #chatMessages {
        overscroll-behavior-x: none;
        touch-action: pan-y pinch-zoom;
    }

    .chat-message {
        touch-action: pan-y pinch-zoom;
    }

    .chat-message.chat-message-swipe-active {
        z-index: 12;
        contain: layout style;
    }

    /* Wisch nur Bubble/Zitat — GPU-Layer, eine CSS-Variable pro Frame */
    .chat-message.chat-message-swipe-active > .chat-message-wrapper,
    .chat-message.chat-message-swipe-active
        > .chat-message-edited-below-stack
        > .chat-message-wrapper {
        transform: translate3d(var(--chat-swipe-offset-x, 0), 0, 0);
        transition: none !important;
        will-change: transform;
        backface-visibility: hidden;
        -webkit-backface-visibility: hidden;
    }

    .chat-message.chat-message-swipe-resetting > .chat-message-wrapper,
    .chat-message.chat-message-swipe-resetting
        > .chat-message-edited-below-stack
        > .chat-message-wrapper {
        transition: transform 200ms cubic-bezier(0.25, 1, 0.35, 1) !important;
        transform: translate3d(0, 0, 0) !important;
        will-change: transform;
    }

    .chat-message.chat-message-swipe-active .chat-message-avatar,
    .chat-message.chat-message-swipe-active .chat-message-avatar-column,
    .chat-message.chat-message-swipe-active .chat-message-avatar-column--with-delivery,
    .chat-message.chat-message-swipe-active .chat-message-avatar-spacer,
    .chat-message.chat-message-swipe-active .chat-message-edit-btn-spacer,
    .chat-message.chat-message-swipe-active .chat-message-edited-below-avatar-wrap,
    .chat-message.chat-message-swipe-active .chat-message-delivery-aside-slot {
        transform: none !important;
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-info::after {
        content: '';
        position: absolute;
        top: 50%;
        width: 22px;
        height: 22px;
        border-radius: 50%;
        border: 2px solid #1d4ed8;
        box-sizing: border-box;
        transform: translate3d(0, -50%, 0) scale(calc(0.9 + (var(--chat-swipe-progress, 0) * 0.12)));
        opacity: calc(0.18 + (var(--chat-swipe-progress, 0) * 0.82));
        pointer-events: none;
        background: rgba(255, 255, 255, 0.92);
        will-change: opacity, transform;
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-info::before {
        content: '';
        position: absolute;
        top: 50%;
        width: 7px;
        height: 7px;
        border-left: 2px solid #1d4ed8;
        border-bottom: 2px solid #1d4ed8;
        pointer-events: none;
        opacity: calc(0.2 + (var(--chat-swipe-progress, 0) * 0.8));
        z-index: 1;
        will-change: opacity;
    }

    .chat-message.chat-message-swipe-active-incoming::after {
        left: -2px;
    }

    .chat-message.chat-message-swipe-active-incoming::before {
        left: 5px;
        transform: translateY(-50%) rotate(225deg);
    }

    .chat-message.chat-message-swipe-active-outgoing::after {
        right: -2px;
    }

    .chat-message.chat-message-swipe-active-outgoing::before {
        right: 5px;
        transform: translateY(-50%) rotate(45deg);
    }

    /* Antwort-Wisch: kein Info-Kreis/Pfeil — Verlauf via Preview oder festes Reply-Highlight */
    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply:not(.chat-message-reply-swipe-preview):not(.chat-message-reply-target-active)::after,
    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply:not(.chat-message-reply-swipe-preview):not(.chat-message-reply-target-active)::before {
        display: none !important;
        content: none !important;
        opacity: 0 !important;
    }

    .chat-message.chat-message-swipe-active.chat-message-reply-target-active::before {
        display: block !important;
        content: '' !important;
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply.chat-message-reply-swipe-preview {
        contain: none;
        overflow: visible;
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply.chat-message-reply-swipe-preview::before {
        display: block !important;
        content: '' !important;
        position: absolute;
        top: 0;
        bottom: 0;
        left: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
        right: calc(-1 * var(--kinma-chat-messages-pad-x, 16px));
        width: auto;
        z-index: 0;
        pointer-events: none;
        border-radius: 0;
        animation: none !important;
        opacity: var(--kinma-reply-highlight-strength, 0) !important;
        transform: scaleX(var(--kinma-reply-highlight-strength, 0)) !important;
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply.chat-message-reply-swipe-preview.chat-message-bot::before {
        transform-origin: left center;
        background: linear-gradient(
            to left,
            transparent var(--kinma-chat-wall-gradient-fade-in, 28%),
            color-mix(in srgb, var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 35%, transparent)
                var(--kinma-chat-wall-gradient-mid-in, 58%),
            var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 100%
        );
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply.chat-message-reply-swipe-preview.chat-message-user::before {
        transform-origin: right center;
        background: linear-gradient(
            to left,
            var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 0%,
            color-mix(in srgb, var(--kinma-chat-reply-highlight-bg, rgba(214, 231, 255, 0.96)) 35%, transparent)
                var(--kinma-chat-wall-gradient-mid, 42%),
            transparent var(--kinma-chat-wall-gradient-fade, 72%)
        );
    }

    .chat-message.chat-message-swipe-active.chat-message-swipe-mode-reply.chat-message-reply-swipe-preview > * {
        position: relative;
        z-index: 1;
    }

    /* Nach außen wischen (Infos): Pfeil/Hinweis auf der gegenüberliegenden Seite */
    .chat-message.chat-message-swipe-active-incoming.chat-message-swipe-mode-info::after {
        left: auto;
        right: -2px;
    }

    .chat-message.chat-message-swipe-active-incoming.chat-message-swipe-mode-info::before {
        left: auto;
        right: 5px;
        transform: translateY(-50%) rotate(45deg);
    }

    .chat-message.chat-message-swipe-active-outgoing.chat-message-swipe-mode-info::after {
        right: auto;
        left: -2px;
    }

    .chat-message.chat-message-swipe-active-outgoing.chat-message-swipe-mode-info::before {
        right: auto;
        left: 5px;
        transform: translateY(-50%) rotate(225deg);
    }

    .chat-messages.chat-messages-swipe-lock,
    #chatMessages.chat-messages-swipe-lock {
        overflow-y: hidden !important;
        overscroll-behavior: contain !important;
    }
}

/* Nachrichteninfo-Modal (Lese-/Zustellstatus, Family-Chat) */
.kinma-chat-message-receipt-overlay {
    position: fixed;
    inset: 0;
    z-index: 100130;
    background: rgba(26, 26, 26, 0.45);
    display: flex;
    align-items: flex-end;
    justify-content: center;
    padding: 12px;
    -webkit-tap-highlight-color: transparent;
}

@media (min-width: 769px) {
    .kinma-chat-message-receipt-overlay {
        align-items: center;
    }
}

.kinma-chat-message-receipt-sheet {
    width: 100%;
    max-width: 400px;
    max-height: min(72vh, 540px);
    overflow: auto;
    background: #ffffff;
    border-radius: 20px;
    box-shadow: 0 18px 50px rgba(26, 26, 26, 0.22);
}

.kinma-chat-message-receipt-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid rgba(148, 163, 184, 0.22);
}

.kinma-chat-message-receipt-title {
    margin: 0;
    font-size: 1.05rem;
    font-weight: 600;
    color: #1a1a1a;
}

.kinma-chat-message-receipt-close {
    flex-shrink: 0;
    width: 40px;
    height: 40px;
    border: none;
    border-radius: 12px;
    background: transparent;
    color: #64748b;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.kinma-chat-message-receipt-close:hover {
    background: #f1f5f9;
    color: #1a1a1a;
}

.kinma-chat-message-receipt-body {
    padding: 14px 16px 18px;
    font-size: 0.95rem;
    color: #1a1a1a;
}

.kinma-chat-message-receipt-loading {
    text-align: center;
    padding: 12px 0;
    color: #64748b;
}

.kinma-chat-message-receipt-line {
    margin: 0 0 10px;
    line-height: 1.45;
}

.kinma-chat-message-receipt-note,
.kinma-chat-message-receipt-muted {
    margin: 0;
    color: #64748b;
    font-size: 0.9rem;
    line-height: 1.4;
}

.kinma-chat-message-receipt-error {
    margin: 0;
    color: #b91c1c;
}

.kinma-chat-message-receipt-list {
    list-style: none;
    margin: 8px 0 0;
    padding: 0;
}

.kinma-chat-message-receipt-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid rgba(148, 163, 184, 0.15);
}

.kinma-chat-message-receipt-row:last-child {
    border-bottom: none;
}

.kinma-chat-message-receipt-name {
    font-weight: 500;
    color: #1a1a1a;
}

.kinma-chat-message-receipt-status {
    flex-shrink: 0;
    font-size: 0.85rem;
    color: #64748b;
    text-align: right;
}

@media (max-width: 768px) {
    .chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
    .chat-message-quote-context:has(.chat-message-references-list.is-expanded),
    .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded),
    .chat-message-quote-context:has(.chat-message-nested-references.is-expanded) {
        overflow: visible !important;
    }

    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-nested--reply-target-refs .chat-message-reference:has(> .chat-message-nested-references.is-expanded) {
        border-top-left-radius: 0 !important;
        border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
        border-top-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
        border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
    }

    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-reference:has(> .chat-message-nested-references.is-expanded),
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-nested--reply-target-refs .chat-message-reference:has(> .chat-message-nested-references.is-expanded) {
        border-top-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
        border-bottom-left-radius: var(--kinma-quote-card-r-row, 12px) !important;
        border-top-right-radius: 0 !important;
        border-bottom-right-radius: var(--kinma-quote-card-r-row, 12px) !important;
    }

    .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded {
        margin: 0 !important;
        padding: 0 !important;
        border-radius: 0 !important;
        background: transparent !important;
    }

    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references.chat-message-references--in-quote-stack {
        background: linear-gradient(
            to left,
            var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade-in, 28%),
            color-mix(in srgb, var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
                var(--kinma-chat-wall-gradient-mid-in, 58%),
            var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 100%
        ) !important;
        padding: 0 !important;
    }

    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-stack .chat-message-quote-primary .chat-message-quote-nested--reply-target-refs .chat-message-nested-references.is-expanded .chat-message-references.chat-message-references--in-quote-stack {
        background: linear-gradient(
            to left,
            var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 0%,
            color-mix(in srgb, var(--chat-quote-context-bg, rgba(254, 243, 199, 0.98)) 38%, var(--kinma-chat-quote-gradient-fade, #ffffff))
                var(--kinma-chat-wall-gradient-mid, 42%),
            var(--kinma-chat-quote-gradient-fade, #ffffff) var(--kinma-chat-wall-gradient-fade, 72%)
        ) !important;
        padding: 0 !important;
    }

    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded),
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded),
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-context:has(.chat-message-nested-references.is-expanded) {
        border-top-left-radius: var(--kinma-quote-card-r-expanded, 16px) !important;
        border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
        border-top-right-radius: 0 !important;
        border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
    }

    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary:has(.chat-message-references-list.is-expanded),
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary:has(.chat-message-nested-references.is-expanded),
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-context:has(.chat-message-references-list.is-expanded),
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-context:has(.chat-message-nested-references.is-expanded) {
        border-top-left-radius: 0 !important;
        border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
        border-top-right-radius: var(--kinma-quote-card-r-expanded, 16px) !important;
        border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
    }

    .chat-message-quote-stack {
        margin-bottom: 2px;
        --chat-quote-thread-glyph-cx: 7px;
        --chat-quote-thread-toggle-cx: calc(10px + 7px);
    }

    .chat-message-quote-stack .chat-message-reference:not(.chat-message-reference--no-index) > .chat-message-nested-references {
        --chat-thread-cx: calc(24px + 8px + 7px);
    }

    .chat-message-quote-stack .chat-message-quote-context-body .chat-message-reference:not(.chat-message-reference--no-index) > .chat-message-nested-references {
        --chat-thread-cx: calc(24px + 10px + 7px);
    }

    .chat-message-quote-stack {
        --kinma-quote-compact-row-py: 7px;
        --kinma-quote-compact-row-px: 9px;
        --kinma-quote-compact-row-gap: 6px;
        --kinma-quote-compact-inline-size: 22px;
        --kinma-quote-compact-glyph-size: 14px;
        --kinma-quote-compact-chevron-size: 14px;
        --chat-quote-thread-nested-avatar-cx: calc(24px + 6px + 7px);
    }

    .chat-message-quote-stack .chat-message-reply-header,
    .chat-message-quote-stack .chat-message-reference-header {
        gap: var(--kinma-quote-compact-row-gap);
        align-items: center;
    }

    .chat-message-quote-stack .chat-message-reply-content,
    .chat-message-quote-stack .chat-message-reference-content {
        gap: var(--kinma-quote-compact-row-gap);
    }

    .chat-message-quote-stack .chat-message-inline-glyph svg,
    .chat-message-quote-stack .chat-message-inline-glyph--reference svg {
        width: 12px;
        height: 12px;
    }

    .chat-message-quote-stack .chat-message-reply-text,
    .chat-message-quote-stack .chat-message-reference-text,
    .chat-message-quote-stack .chat-message-references-toggle-label {
        font-size: 11px;
        font-weight: 500;
        line-height: 1.35;
    }

    .chat-message-quote-stack .chat-message-references--multi-collapse .chat-message-references-toggle,
    .chat-message-quote-nested--reply-target-refs .chat-message-references--multi-collapse .chat-message-references-toggle,
    .chat-message-quote-stack .chat-message-references:not(.chat-message-references--multi-collapse) .chat-message-references-toggle {
        padding: var(--kinma-quote-compact-row-py) var(--kinma-quote-compact-row-px);
        gap: var(--kinma-quote-compact-row-gap);
        height: var(--kinma-quote-compact-row-min-h);
        min-height: var(--kinma-quote-compact-row-min-h);
    }

    .chat-message-quote-stack .chat-message-references-list .chat-message-reference,
    .chat-message-quote-stack .chat-message-nested-references-list .chat-message-reference {
        padding: var(--kinma-quote-compact-row-py) var(--kinma-quote-compact-row-px);
        min-height: var(--kinma-quote-compact-row-min-h);
    }

    .chat-message-quote-stack .chat-message-nested-references {
        padding: 4px 8px 6px;
    }
}

.chat-message-grouped {
    margin-top: 0;
    margin-bottom: 0;
}

/* >5 Min seit der Nachricht davor — Abstand unabhängig vom Absender (siehe auch #chatMessages Adjacent-Regeln) */
.chat-message-time-cluster-start {
    margin-top: 16px;
}

.chat-message-after-side-break {
    margin-top: 10px;
}

.chat-message-content {
    padding: 10px 14px;
    border-radius: 18px;
    font-size: 14px;
    line-height: 1.4;
    word-wrap: break-word;
    overflow-wrap: break-word;
    word-break: break-word;
    white-space: normal;
    max-width: 100%;
    hyphens: auto;
    -webkit-hyphens: auto;
    -moz-hyphens: auto;
    -ms-hyphens: auto;
    display: flex;
    flex-direction: column;
    gap: 6px;
    border: none;
    outline: none;
    box-shadow: none;
}

.chat-message-content.chat-message-pill {
    border-radius: 24px;
    padding: 8px 16px;
    gap: 4px;
}

.chat-message-text {
    word-wrap: break-word;
    overflow-wrap: break-word;
    line-height: 1.4;
}

.chat-attachment-temporary-photo {
    margin: 8px 0;
}

.chat-temporary-photo-btn {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
    border: none;
    padding: 12px 24px;
    border-radius: 12px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(102, 126, 234, 0.3);
}

.chat-temporary-photo-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.4);
}

.chat-temporary-photo-btn:active {
    transform: translateY(0);
}

.chat-temporary-photo-btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
    transform: none;
}

.chat-temporary-photo-deleted {
    padding: 12px 24px;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 12px;
    color: #6c757d;
    font-size: 14px;
    text-align: center;
    font-style: italic;
}

.chat-poll-dialog {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.5);
    z-index: 100000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-poll-dialog-content {
    background: white;
    border-radius: 16px;
    width: 90%;
    max-width: 500px;
    max-height: 90vh;
    display: flex;
    flex-direction: column;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2);
}

.chat-poll-dialog-header {
    padding: 20px;
    border-bottom: 1px solid #e9ecef;
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.chat-poll-dialog-header h3 {
    margin: 0;
    font-size: 18px;
    font-weight: 600;
    color: #1a1a1a;
}

.chat-poll-dialog-close {
    background: none;
    border: none;
    font-size: 24px;
    color: #6c757d;
    cursor: pointer;
    padding: 0;
    width: 30px;
    height: 30px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    transition: background 0.2s ease;
}

.chat-poll-dialog-close:hover {
    background: #f8f9fa;
}

.chat-poll-dialog-body {
    padding: 20px;
    overflow-y: auto;
    flex: 1;
}

.chat-poll-input-group {
    margin-bottom: 20px;
}

.chat-poll-input-group label {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
    color: #1a1a1a;
    font-size: 14px;
}

.chat-poll-input-group input {
    width: 100%;
    padding: 12px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
}

.chat-poll-input-group input:focus {
    outline: none;
    border-color: #667eea;
}

.chat-poll-options-container {
    margin-bottom: 16px;
}

.chat-poll-option-item {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 12px;
}

.chat-poll-add-option-btn {
    background: #f8f9fa;
    border: 1px dashed #dee2e6;
    color: #6c757d;
    padding: 10px 16px;
    border-radius: 8px;
    cursor: pointer;
    font-size: 14px;
    transition: all 0.2s ease;
    width: 100%;
}

.chat-poll-add-option-btn:hover {
    background: #e9ecef;
    border-color: #adb5bd;
    color: #1a1a1a;
}

.chat-poll-dialog-footer {
    padding: 16px 20px;
    border-top: 1px solid #e9ecef;
    display: flex;
    gap: 12px;
    justify-content: flex-end;
}

.chat-poll-btn {
    padding: 10px 20px;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 500;
    cursor: pointer;
    border: none;
    transition: all 0.2s ease;
}

.chat-poll-btn-cancel {
    background: #f8f9fa;
    color: #6c757d;
}

.chat-poll-btn-cancel:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-poll-btn-create {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
    color: white;
}

.chat-poll-btn-create:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3);
}

.chat-poll-input-group textarea#pollAiContext {
    width: 100%;
    padding: 12px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    font-size: 14px;
    box-sizing: border-box;
    font-family: inherit;
    resize: vertical;
    min-height: 72px;
}

.chat-poll-input-group textarea#pollAiContext:focus {
    outline: none;
    border-color: #667eea;
}

.chat-poll-optional-label {
    font-weight: 400;
    color: #6c757d;
    font-size: 13px;
}

.chat-poll-ai-hint {
    font-size: 13px;
    color: #6c757d;
    margin-top: 12px;
    line-height: 1.45;
}

/* KI-Modus: synthetische Umfrage-Karte (kein Datei-Upload) */
.chat-attachment-ai-poll {
    margin-top: 8px;
    max-width: 100%;
}

.kinma-ai-poll-card {
    background: rgba(255, 255, 255, 0.92);
    border: 1px solid rgba(102, 126, 234, 0.35);
    border-radius: 12px;
    padding: 12px 14px;
    box-shadow: 0 4px 14px rgba(26, 26, 26, 0.06);
}

.kinma-ai-poll-card-title {
    font-weight: 600;
    font-size: 15px;
    color: #1a1a1a;
    margin-bottom: 6px;
}

.kinma-ai-poll-card-context {
    font-size: 13px;
    color: #1a1a1a;
    font-style: italic;
    margin-bottom: 10px;
    line-height: 1.4;
}

.kinma-ai-poll-card-options {
    margin: 0 0 10px 0;
    padding-left: 1.25rem;
    color: #1a1a1a;
    font-size: 14px;
    line-height: 1.5;
}

.kinma-ai-poll-card-options li {
    margin-bottom: 4px;
}

.kinma-ai-poll-card-note {
    font-size: 11px;
    color: #64748b;
    border-top: 1px solid rgba(148, 163, 184, 0.35);
    padding-top: 8px;
    margin-top: 4px;
}

.chat-message-poll {
    background: linear-gradient(180deg, #ffffff 0%, #f8fafc 100%);
    border-radius: 18px;
    padding: 16px;
    margin: 8px 0;
    border: 1px solid rgba(148, 163, 184, 0.22);
    box-shadow: 0 10px 24px rgba(26, 26, 26, 0.08);
}

.chat-poll-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.chat-poll-kicker {
    display: inline-flex;
    align-items: center;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(99, 102, 241, 0.1);
    color: #4f46e5;
    font-size: 12px;
    font-weight: 700;
}

.chat-poll-question {
    font-weight: 700;
    font-size: 16px;
    line-height: 1.35;
    color: #1a1a1a;
    margin-bottom: 14px;
}

.chat-poll-options {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.chat-poll-option {
    background: #ffffff;
    border: 1px solid rgba(148, 163, 184, 0.22);
    border-radius: 16px;
    padding: 12px 14px;
    cursor: pointer;
    transition: all 0.2s ease;
    position: relative;
    overflow: hidden;
}

.chat-poll-option:hover {
    border-color: rgba(99, 102, 241, 0.45);
    transform: translateY(-1px);
    box-shadow: 0 8px 20px rgba(99, 102, 241, 0.1);
}

.chat-poll-option.voted {
    border-color: rgba(79, 70, 229, 0.45);
    background: #f8faff;
}

.chat-poll-option-bar-bg {
    position: absolute;
    inset: 0;
    background: rgba(241, 245, 249, 0.85);
}

.chat-poll-option-bar-fill {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    min-width: 10px;
    opacity: 0.18;
    transition: width 0.3s ease;
}

.chat-poll-option-content {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 12px;
}

.chat-poll-option-main {
    min-width: 0;
    flex: 1 1 auto;
}

.chat-poll-option-text {
    font-size: 14px;
    color: #1a1a1a;
    font-weight: 600;
    line-height: 1.35;
}

.chat-poll-option-badge {
    display: inline-flex;
    align-items: center;
    margin-top: 8px;
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(79, 70, 229, 0.12);
    color: #4f46e5;
    font-size: 11px;
    font-weight: 700;
}

.chat-poll-option-side {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: center;
    gap: 3px;
    flex-shrink: 0;
}

.chat-poll-option-percentage {
    font-size: 15px;
    font-weight: 800;
    color: #1a1a1a;
}

.chat-poll-option-votes {
    font-size: 12px;
    color: #64748b;
}

.chat-poll-total-votes {
    font-size: 12px;
    color: #64748b;
    font-weight: 600;
}

.chat-message-content--location-card {
    min-width: min(100%, 280px);
    max-width: 320px;
}

.chat-message-location {
    margin: 0;
    border-radius: 14px;
    overflow: hidden;
    border: 1px solid rgba(26, 26, 26, 0.08);
    box-shadow: 0 4px 14px rgba(26, 26, 26, 0.06);
    background: #fff;
}

.chat-message-location--card .chat-location-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 10px 12px 8px;
    background: linear-gradient(180deg, #f8fafc 0%, #fff 100%);
    border-bottom: 1px solid rgba(26, 26, 26, 0.06);
}

.chat-location-card-title {
    font-size: 14px;
    font-weight: 700;
    color: #1a1a1a;
    letter-spacing: -0.01em;
}

.chat-location-card-badge {
    font-size: 11px;
    font-weight: 600;
    color: #0369a1;
    background: rgba(14, 165, 233, 0.12);
    padding: 4px 8px;
    border-radius: 999px;
    white-space: nowrap;
}

.chat-location-map {
    width: 100%;
    height: 200px;
    background: #e2e8f0;
    border-radius: 0;
}

.chat-message-location--card .chat-location-map {
    min-height: 200px;
}

.chat-location-info {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 10px;
    padding: 10px 12px 12px;
    background: #f8fafc;
    border-top: 1px solid rgba(26, 26, 26, 0.06);
}

.chat-location-live-hint {
    font-size: 12px;
    line-height: 1.35;
    color: #64748b;
    flex: 1;
    min-width: 0;
}

.chat-location-label {
    font-size: 14px;
    color: #1a1a1a;
    font-weight: 500;
}

.chat-location-link {
    font-size: 12px;
    color: #667eea;
    text-decoration: none;
    transition: color 0.2s ease;
}

.chat-location-link:hover {
    color: #764ba2;
    text-decoration: underline;
}

.chat-message-location.expired {
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 12px;
    padding: 16px;
}

.chat-location-expired-message {
    text-align: center;
    color: #6c757d;
    font-size: 14px;
    font-style: italic;
}

.chat-location-map-container {
    position: relative;
}

.chat-location-loading {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    background: #f8f9fa;
    border-radius: 8px;
}

.chat-temporary-photo-modal {
    animation: fadeIn 0.2s ease;
}

.chat-main {
    position: relative;
}

.chat-temporary-photo-modal img {
    max-width: 90%;
    max-height: 90%;
    object-fit: contain;
}

.chat-image-modal {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-image-modal-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(0, 0, 0, 0.9);
    cursor: pointer;
}

.chat-image-modal-content {
    position: relative;
    max-width: 90%;
    max-height: 90%;
    z-index: 1;
}

.chat-image-modal-close {
    position: absolute;
    top: -40px;
    right: 0;
    background: transparent;
    border: none;
    color: white;
    font-size: 32px;
    cursor: pointer;
    line-height: 1;
    padding: 0;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.chat-image-modal-close:hover {
    opacity: 0.7;
}

.chat-image-modal-img {
    max-width: 100%;
    max-height: 80vh;
    object-fit: contain;
    border-radius: 8px;
}

.chat-image-modal-name {
    position: absolute;
    bottom: -40px;
    left: 0;
    right: 0;
    text-align: center;
    color: white;
    font-size: 14px;
}

.chat-message-meta {
    display: none; /* Hide time from inside message box */
}

.chat-message-actions {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-top: 4px;
}

.chat-message-bot .chat-message-actions {
    justify-content: flex-start;
}

.chat-message-user .chat-message-actions {
    justify-content: flex-end;
}

.chat-message-bot .chat-message-content {
    --kinma-incoming-fg: #ffffff;
    --kinma-incoming-fg-muted: rgba(255, 255, 255, 0.72);
    background: var(--kinma-incoming-bubble-bg, #212121);
    color: var(--kinma-incoming-fg);
    border: none;
    outline: none;
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
    align-self: flex-start;
    box-shadow: none;
}

/* Markdown in eingehenden Blasen (dunkle Blase: helle Schrift, Lesekontrast für Code/Links) */
.chat-message-bot .chat-message-content .chat-message-text,
.chat-message-bot .chat-message-content p {
    color: inherit;
}
.chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list,
.chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list {
    margin: 6px 0 6px 18px;
    padding: 0;
}

.chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list ol.kinma-ai-rt-list,
.chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list ol.kinma-ai-rt-list {
    margin-top: 4px;
    margin-bottom: 4px;
}

.chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list li,
.chat-message-bot .chat-message-content .chat-message-text ol.kinma-ai-rt-list li {
    margin: 2px 0;
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-linehead {
    margin: 6px 0 2px;
    font-weight: 600;
    line-height: 1.4;
}

.chat-message-bot .chat-message-content .chat-message-text ul.kinma-ai-rt-list--inline-semi {
    margin: 2px 0 8px 1.25rem;
    padding-left: 1.1rem;
    list-style-type: disc;
}

.chat-message-bot .chat-message-content .chat-message-text code.kinma-ai-rt-code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.92em;
    background: rgba(255, 255, 255, 0.12);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 6px;
    padding: 1px 6px;
    color: #f8fafc;
}

.chat-message-bot .chat-message-content .chat-message-text a.kinma-ai-chat-link {
    color: #7dd3fc;
    text-decoration: underline;
    word-break: break-word;
}

.chat-message-bot .chat-message-content .chat-message-text a.kinma-ai-chat-link:hover {
    color: #bae6fd;
}

.chat-message-bot .chat-message-content .chat-message-text a.kinma-ai-chat-link--internal {
    font-weight: 600;
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h1,
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h2,
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h3,
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h4 {
    font-weight: 800;
    margin: 8px 0 4px;
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h1 { font-size: 1.14em; }
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h2 { font-size: 1.10em; }
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h3 { font-size: 1.06em; }
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-h4 { font-size: 1.03em; }

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap {
    margin: 8px 0;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(0, 0, 0, 0.35);
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-lang {
    display: block;
    font-size: 0.75rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    padding: 4px 10px;
    color: rgba(255, 255, 255, 0.75);
    background: rgba(255, 255, 255, 0.08);
    border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-pre {
    margin: 0;
    padding: 8px 10px;
    overflow-x: auto;
    font-size: 0.88em;
    line-height: 1.45;
    background: transparent;
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-body {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    white-space: pre-wrap;
    word-break: break-word;
    color: #e2e8f0;
    display: block;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap--rendered-md .kinma-ai-rt-fence-md {
    padding: 8px 10px;
    font-size: 0.95em;
    line-height: 1.5;
    color: #e2e8f0;
}

.chat-message-bot .chat-message-content .chat-message-text .katex {
    font-size: 1.05em;
    color: inherit;
}

.chat-message-bot .chat-message-content .chat-message-text .katex-display {
    margin: 0.55em 0;
    overflow-x: auto;
    max-width: 100%;
}

/* Blockiertes / ungültiges iframe (z. B. example.com aus Modell-Doku) */
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-rt-embed-skipped {
    margin: 8px 0 0;
    font-size: 13px;
    line-height: 1.4;
    color: rgba(255, 255, 255, 0.62);
    font-style: italic;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-embed-skipped,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-embed-skipped {
    margin: 8px 0 0;
    font-size: 13px;
    line-height: 1.4;
    color: rgba(26, 26, 26, 0.65);
    font-style: italic;
}

/* Eingebettete iframes (KI-Chat, nach src-Whitelist) */
.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-chat-iframe-wrap {
    position: relative;
    margin: 10px 0;
    max-width: 100%;
    border-radius: 10px;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.08);
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-chat-iframe-wrap,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-chat-iframe-wrap {
    position: relative;
    margin: 10px 0;
    max-width: 100%;
    border-radius: 10px;
    overflow: hidden;
    background: rgba(26, 26, 26, 0.06);
    border: 1px solid rgba(26, 26, 26, 0.12);
}

.kinma-ai-chat-embed-iframe {
    display: block;
    width: 100%;
    min-height: 200px;
    max-height: min(70vh, 520px);
    border: 0;
    vertical-align: bottom;
}

/* Ladezustand über eingebetteten iframes bis load/error */
.kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading {
    position: absolute;
    inset: 0;
    z-index: 12;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(26, 26, 26, 0.55);
    border-radius: inherit;
    transition: opacity 0.28s ease;
    pointer-events: none;
}

.kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading--hidden {
    opacity: 0;
}

.kinma-ai-chat-iframe-loading-spinner {
    width: 40px;
    height: 40px;
    border: 3px solid rgba(255, 255, 255, 0.22);
    border-top-color: rgba(255, 255, 255, 0.92);
    border-radius: 50%;
    animation: kinma-ai-iframe-loading-spin 0.75s linear infinite;
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading,
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading {
    background: rgba(248, 250, 252, 0.94);
}

.chat-message-bot .chat-message-content .chat-message-text .kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading-spinner,
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading-spinner,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-chat-iframe-wrap .kinma-ai-chat-iframe-loading-spinner {
    border-color: rgba(26, 26, 26, 0.12);
    border-top-color: rgba(26, 26, 26, 0.55);
}

@keyframes kinma-ai-iframe-loading-spin {
    to {
        transform: rotate(360deg);
    }
}

/* Kinma same-origin preview: 16:9- bzw. 9:16-Box, Stage füllt Box; iframe 1280×720 / 390×693 + transform im JS */
.kinma-ai-chat-iframe-wrap--same-site-preview {
    position: relative;
}

.kinma-ai-chat-iframe-wrap--same-site-preview .kinma-ai-iframe-preview-box {
    position: relative;
    width: 100%;
    max-width: 100%;
}

.kinma-ai-chat-iframe-wrap--preview-desktop .kinma-ai-iframe-preview-box {
    aspect-ratio: 16 / 9;
}

.kinma-ai-chat-iframe-wrap--preview-mobile .kinma-ai-iframe-preview-box {
    aspect-ratio: 9 / 16;
    max-width: min(100%, 420px);
    margin-left: auto;
    margin-right: auto;
}

.kinma-ai-chat-iframe-wrap--same-site-preview .kinma-ai-iframe-preview-stage {
    position: absolute;
    inset: 0;
    overflow: hidden;
    z-index: 0;
}

.kinma-ai-chat-iframe-wrap--same-site-preview .kinma-ai-chat-embed-iframe {
    display: block;
    box-sizing: border-box;
    min-height: 0;
    max-height: none;
    max-width: none;
    border: 0;
    vertical-align: bottom;
    pointer-events: none;
}

.chat-message-user .chat-message-content {
    --kinma-outgoing-fg: #1a1a1a;
    --kinma-outgoing-fg-muted: rgba(26, 26, 26, 0.72);
    background: var(--kinma-outgoing-bubble-bg, #d4cff5);
    color: var(--kinma-outgoing-fg);
    border: none;
    outline: none;
    border-bottom-right-radius: 0;
    border-top-right-radius: 0;
    align-self: flex-end;
    box-shadow: none;
}

/* Markdown in ausgehenden (und gespiegelten) Textblasen — gleiche Klassen wie KI-Renderer */
.chat-message-user .chat-message-content .chat-message-text ul.kinma-ai-rt-list,
.chat-message-user .chat-message-content .chat-message-text ol.kinma-ai-rt-list,
.chat-message-user .chat-message-body .chat-message-text ul.kinma-ai-rt-list,
.chat-message-user .chat-message-body .chat-message-text ol.kinma-ai-rt-list {
    margin: 6px 0 6px 18px;
    padding: 0;
}

.chat-message-user .chat-message-content .chat-message-text ul.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-message-user .chat-message-content .chat-message-text ul.kinma-ai-rt-list ol.kinma-ai-rt-list,
.chat-message-user .chat-message-content .chat-message-text ol.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-message-user .chat-message-content .chat-message-text ol.kinma-ai-rt-list ol.kinma-ai-rt-list,
.chat-message-user .chat-message-body .chat-message-text ul.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-message-user .chat-message-body .chat-message-text ul.kinma-ai-rt-list ol.kinma-ai-rt-list,
.chat-message-user .chat-message-body .chat-message-text ol.kinma-ai-rt-list ul.kinma-ai-rt-list,
.chat-message-user .chat-message-body .chat-message-text ol.kinma-ai-rt-list ol.kinma-ai-rt-list {
    margin-top: 4px;
    margin-bottom: 4px;
}

.chat-message-user .chat-message-content .chat-message-text ul.kinma-ai-rt-list li,
.chat-message-user .chat-message-content .chat-message-text ol.kinma-ai-rt-list li,
.chat-message-user .chat-message-body .chat-message-text ul.kinma-ai-rt-list li,
.chat-message-user .chat-message-body .chat-message-text ol.kinma-ai-rt-list li {
    margin: 2px 0;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-linehead,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-linehead {
    margin: 6px 0 2px;
    font-weight: 600;
    line-height: 1.4;
}

.chat-message-user .chat-message-content .chat-message-text ul.kinma-ai-rt-list--inline-semi,
.chat-message-user .chat-message-body .chat-message-text ul.kinma-ai-rt-list--inline-semi {
    margin: 2px 0 8px 1.25rem;
    padding-left: 1.1rem;
    list-style-type: disc;
}

.chat-message-user .chat-message-content .chat-message-text code.kinma-ai-rt-code,
.chat-message-user .chat-message-body .chat-message-text code.kinma-ai-rt-code {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    font-size: 0.92em;
    background: #f1f5f9;
    border: 1px solid #e2e8f0;
    border-radius: 6px;
    padding: 1px 6px;
    color: #1a1a1a;
}

.chat-message-user .chat-message-content .chat-message-text a.kinma-ai-chat-link,
.chat-message-user .chat-message-body .chat-message-text a.kinma-ai-chat-link {
    color: #4f46e5;
    text-decoration: underline;
    word-break: break-word;
}

.chat-message-user .chat-message-content .chat-message-text a.kinma-ai-chat-link:hover,
.chat-message-user .chat-message-body .chat-message-text a.kinma-ai-chat-link:hover {
    color: #4338ca;
}

.chat-message-user .chat-message-content .chat-message-text a.kinma-ai-chat-link--internal,
.chat-message-user .chat-message-body .chat-message-text a.kinma-ai-chat-link--internal {
    font-weight: 600;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h1,
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h2,
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h3,
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h4,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h1,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h2,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h3,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h4 {
    font-weight: 800;
    margin: 8px 0 4px;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h1,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h1 { font-size: 1.14em; }
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h2,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h2 { font-size: 1.10em; }
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h3,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h3 { font-size: 1.06em; }
.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-h4,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-h4 { font-size: 1.03em; }

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-fence-wrap {
    margin: 8px 0;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid #e2e8f0;
    background: #f8fafc;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-fence-lang,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-fence-lang {
    display: block;
    font-size: 0.75rem;
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    padding: 4px 10px;
    color: #1a1a1a;
    background: #f1f5f9;
    border-bottom: 1px solid #e2e8f0;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-pre,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-pre {
    margin: 0;
    padding: 8px 10px;
    overflow-x: auto;
    font-size: 0.88em;
    line-height: 1.45;
    background: transparent;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-fence-body,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-fence-body {
    font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    white-space: pre-wrap;
    word-break: break-word;
    color: #1a1a1a;
    display: block;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
}

.chat-message-user .chat-message-content .chat-message-text .kinma-ai-rt-fence-wrap--rendered-md .kinma-ai-rt-fence-md,
.chat-message-user .chat-message-body .chat-message-text .kinma-ai-rt-fence-wrap--rendered-md .kinma-ai-rt-fence-md {
    padding: 8px 10px;
    font-size: 0.95em;
    line-height: 1.5;
    color: #1a1a1a;
}

.chat-message-user .chat-message-content .chat-message-text .katex,
.chat-message-user .chat-message-body .chat-message-text .katex {
    font-size: 1.05em;
    color: inherit;
}

.chat-message-user .chat-message-content .chat-message-text .katex-display,
.chat-message-user .chat-message-body .chat-message-text .katex-display {
    margin: 0.55em 0;
    overflow-x: auto;
    max-width: 100%;
}

.chat-message-bot:not(.chat-message-grouped) .chat-message-content {
    border-bottom-left-radius: 12px;
}

.chat-message-user:not(.chat-message-grouped) .chat-message-content {
    border-bottom-right-radius: 12px;
}

.chat-message-bot.chat-message-middle-grouped .chat-message-content {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.chat-message-user.chat-message-middle-grouped .chat-message-content {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

.chat-message-bot.chat-message-last-in-group .chat-message-content {
    border-top-left-radius: 0;
    border-bottom-left-radius: 12px;
}

.chat-message-user.chat-message-last-in-group .chat-message-content {
    border-top-right-radius: 0;
    border-bottom-right-radius: 12px;
}

.chat-message-user.chat-message-last-before-system .chat-message-content {
    border-bottom-right-radius: 12px;
}

.chat-message-bot.chat-message-last-before-system .chat-message-content {
    border-bottom-left-radius: 12px;
}

.chat-message-user.chat-message-first-after-system .chat-message-content {
    border-top-right-radius: 12px !important;
}

.chat-message-bot.chat-message-first-after-system .chat-message-content {
    border-top-left-radius: 12px !important;
}

.chat-message-bot .chat-message-content.chat-message-pill {
    border-bottom-left-radius: 12px;
}

.chat-message-user .chat-message-content.chat-message-pill {
    border-bottom-right-radius: 12px;
}

/*
 * Direkt über einer Antwort (Vorgänger ist keine Reply): Gegenüber der Avatar-Seite wie normale
 * Bubble (tl+bl user / tr+br bot); nur unten an der Avatar-Seite eckig für den Faden.
 */
.chat-message-user.chat-message-above-reply-target > .chat-message-wrapper > .chat-message-content,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-only > .chat-message-wrapper > .chat-message-content,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-first > .chat-message-wrapper > .chat-message-content,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-middle > .chat-message-wrapper > .chat-message-content,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-last > .chat-message-wrapper > .chat-message-content {
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-bl: 0px !important;
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 18px !important;
    --kinma-protrude-br: 0px !important;
    border-bottom-right-radius: 0 !important;
}

.chat-message-user.chat-message-above-reply-target > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-only > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-first > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-middle > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-above-reply-target.chat-message-cluster-last > .chat-message-wrapper > .chat-message-content.chat-message-pill {
    --kinma-protrude-tl: 0 !important;
    --kinma-protrude-bl: 0 !important;
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 24px !important;
    --kinma-protrude-br: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.chat-message-bot.chat-message-above-reply-target > .chat-message-wrapper > .chat-message-content,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-only > .chat-message-wrapper > .chat-message-content,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-first > .chat-message-wrapper > .chat-message-content,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-middle > .chat-message-wrapper > .chat-message-content,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-last > .chat-message-wrapper > .chat-message-content {
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-br: 0px !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 18px !important;
    --kinma-protrude-bl: 0px !important;
    border-bottom-left-radius: 0 !important;
}

.chat-message-bot.chat-message-above-reply-target > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-only > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-first > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-middle > .chat-message-wrapper > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-above-reply-target.chat-message-cluster-last > .chat-message-wrapper > .chat-message-content.chat-message-pill {
    --kinma-protrude-tr: 0 !important;
    --kinma-protrude-br: 0 !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 24px !important;
    --kinma-protrude-bl: 0 !important;
    border-bottom-left-radius: 0 !important;
}

/* 5-Minuten-Cluster: Ecken zur Avatar-Seite (rechts = user, links = bot) — schlägt .chat-message-pill und alte Gruppierung */
/* Einzelnachricht: zur Avatar-Seite (rechts) oben rund, unten eckig */
.chat-message-user.chat-message-cluster-only .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 18px !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 6px !important;
}

.chat-message-user.chat-message-cluster-only .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 24px !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 8px !important;
}

.chat-message-user.chat-message-cluster-first .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 0 !important;
}

.chat-message-user.chat-message-cluster-first .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 0 !important;
}

.chat-message-user.chat-message-cluster-middle .chat-message-content {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.chat-message-user.chat-message-cluster-middle .chat-message-content.chat-message-pill {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: var(--kinma-protrude-bl, 0px) !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

/* Letzte im 5-Min-Cluster (user): oben zur Mitte eckig, unten Außenecke leicht gerundet */
.chat-message-user.chat-message-cluster-last .chat-message-content {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: 18px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 6px !important;
}

.chat-message-user.chat-message-cluster-last .chat-message-content.chat-message-pill {
    border-top-left-radius: var(--kinma-protrude-tl, 0px) !important;
    border-bottom-left-radius: 24px !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 8px !important;
}

/*
 * Ausgehende Antwort: oben Mitte + unten Avatar-Seite eckig — schlägt 5-Min-Cluster + Protrusion + Sandwich.
 */
.chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-only .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-first .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-middle .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-last .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content {
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-bl: 0px !important;
    --kinma-protrude-br: 0px !important;
    border-radius: 0 0 0 18px !important;
}

.chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-only .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-first .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-middle .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-last .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 0 24px !important;
}

/* Ausgehende Antwort: untere Außenecke (rechts) wie normale Bubble bei cluster-only / cluster-last */
.chat-message-user.chat-message-cluster-only.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user.chat-message-cluster-only .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-message-user.chat-message-cluster-last.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-message-user.chat-message-cluster-last .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content {
    border-radius: 0 0 6px 18px !important;
}

.chat-message-user.chat-message-cluster-only.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-cluster-only .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-cluster-last.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-cluster-last .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 8px 24px !important;
}

/* KI-Modus: Antwort-Bubble schlägt cluster-only (pill border-radius: 24px) */
.chat-popup.ai-mode #chatMessages .chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-only .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-first .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-middle .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-last .chat-message-outgoing-stack > .chat-message-content {
    border-radius: 0 0 0 18px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-only .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-first .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-middle .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-user-has-outgoing-quote.chat-message-cluster-last .chat-message-outgoing-stack > .chat-message-content.chat-message-pill {
    border-radius: 0 0 0 24px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-only.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-only .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content {
    border-radius: 0 0 6px 18px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-only.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-only .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last.chat-message-user-has-outgoing-quote .chat-message-outgoing-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-user.chat-message-cluster-last .chat-message-outgoing-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 8px 24px !important;
}

/*
 * Eingehende Antwort: oben Mitte + unten Avatar-Seite eckig (Spiegel zu ausgehend) — schlägt Cluster + Protrusion.
 */
.chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-only .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-first .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-middle .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-last .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    --kinma-protrude-tl: 0px !important;
    --kinma-protrude-tr: 0px !important;
    --kinma-protrude-bl: 0px !important;
    --kinma-protrude-br: 0px !important;
    border-radius: 0 0 18px 0 !important;
}

.chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-only .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-first .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-middle .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-last .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 24px 0 !important;
}

/*
 * Eingehende Antwort: unten links zur Avatar-Seite runden — wie normale Bot-Bubble bei
 * Einzelnachricht im Fenster (cluster-only) oder letzter Nachricht im 5-Min-Cluster (cluster-last).
 */
.chat-message-bot.chat-message-cluster-only.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot.chat-message-cluster-only .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-message-bot.chat-message-cluster-last.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-message-bot.chat-message-cluster-last .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    border-radius: 0 0 18px 6px !important;
}

.chat-message-bot.chat-message-cluster-only.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-cluster-only .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-cluster-last.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-cluster-last .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 24px 8px !important;
}

/* KI-Modus: eingehende Antwort-Bubble — Avatar-Seite links eckig */
.chat-popup.ai-mode #chatMessages .chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-only .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-first .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-middle .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-last .chat-message-incoming-stack > .chat-message-content {
    border-radius: 0 0 18px 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-only .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-first .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-middle .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-bot-has-incoming-quote.chat-message-cluster-last .chat-message-incoming-stack > .chat-message-content.chat-message-pill {
    border-radius: 0 0 24px 0 !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-only.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-only .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content {
    border-radius: 0 0 18px 6px !important;
}

.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-only.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-only .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last.chat-message-bot-has-incoming-quote .chat-message-incoming-stack > .chat-message-content.chat-message-pill,
.chat-popup.ai-mode #chatMessages .chat-message-bot.chat-message-cluster-last .chat-message-incoming-stack:has(.chat-message-quote-above) > .chat-message-content.chat-message-pill {
    border-radius: 0 0 24px 8px !important;
}

/* Einzelnachricht: Ecke zur Avatar-Seite (links) wie ausgehend unten-rechts (6px / 8px Pill) */
.chat-message-bot.chat-message-cluster-only .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 6px !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: 18px !important;
}

.chat-message-bot.chat-message-cluster-only .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 8px !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: 24px !important;
}

.chat-message-bot.chat-message-cluster-first .chat-message-content {
    border-top-left-radius: 18px !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 18px !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-message-bot.chat-message-cluster-first .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: 24px !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-message-bot.chat-message-cluster-middle .chat-message-content {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

.chat-message-bot.chat-message-cluster-middle .chat-message-content.chat-message-pill {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 0 !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: var(--kinma-protrude-br, 0px) !important;
}

/* Letzte im 5-Min-Cluster: Ecke zur Avatar-Seite (links) wie ausgehend (unten-rechts 6px / Pill 8px) */
.chat-message-bot.chat-message-cluster-last .chat-message-content {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 6px !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: 18px !important;
}

.chat-message-bot.chat-message-cluster-last .chat-message-content.chat-message-pill {
    border-top-left-radius: 0 !important;
    border-bottom-left-radius: 8px !important;
    border-top-right-radius: var(--kinma-protrude-tr, 0px) !important;
    border-bottom-right-radius: 24px !important;
}

/* Nach Systemnachricht: oberste Ecke zur Avatar-Seite nur bei Cluster-Anfang / Einzelnachricht */
.chat-message-user.chat-message-first-after-system.chat-message-cluster-first .chat-message-content,
.chat-message-user.chat-message-first-after-system.chat-message-cluster-only .chat-message-content {
    border-top-right-radius: 18px !important;
}

.chat-message-user.chat-message-first-after-system.chat-message-cluster-first .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-first-after-system.chat-message-cluster-only .chat-message-content.chat-message-pill {
    border-top-right-radius: 24px !important;
}

.chat-message-user.chat-message-first-after-system.chat-message-cluster-middle .chat-message-content,
.chat-message-user.chat-message-first-after-system.chat-message-cluster-last .chat-message-content {
    border-top-right-radius: 0 !important;
}

.chat-message-user.chat-message-first-after-system.chat-message-cluster-middle .chat-message-content.chat-message-pill,
.chat-message-user.chat-message-first-after-system.chat-message-cluster-last .chat-message-content.chat-message-pill {
    border-top-right-radius: 0 !important;
}

.chat-message-bot.chat-message-first-after-system.chat-message-cluster-first .chat-message-content,
.chat-message-bot.chat-message-first-after-system.chat-message-cluster-only .chat-message-content {
    border-top-left-radius: 18px !important;
}

.chat-message-bot.chat-message-first-after-system.chat-message-cluster-first .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-first-after-system.chat-message-cluster-only .chat-message-content.chat-message-pill {
    border-top-left-radius: 24px !important;
}

.chat-message-bot.chat-message-first-after-system.chat-message-cluster-middle .chat-message-content,
.chat-message-bot.chat-message-first-after-system.chat-message-cluster-last .chat-message-content {
    border-top-left-radius: 0 !important;
}

.chat-message-bot.chat-message-first-after-system.chat-message-cluster-middle .chat-message-content.chat-message-pill,
.chat-message-bot.chat-message-first-after-system.chat-message-cluster-last .chat-message-content.chat-message-pill {
    border-top-left-radius: 0 !important;
}

/* Keine Schatten auf Nachrichtenblasen (inkl. 5-Min-Cluster; überschreibt style.css cluster-shadow) */
#chatMessages .chat-message-user .chat-message-content,
#chatMessages .chat-message-bot .chat-message-content,
.chat-message-user.chat-message-cluster-only .chat-message-content,
.chat-message-user.chat-message-cluster-first .chat-message-content,
.chat-message-user.chat-message-cluster-middle .chat-message-content,
.chat-message-user.chat-message-cluster-last .chat-message-content,
.chat-message-bot.chat-message-cluster-only .chat-message-content,
.chat-message-bot.chat-message-cluster-first .chat-message-content,
.chat-message-bot.chat-message-cluster-middle .chat-message-content,
.chat-message-bot.chat-message-cluster-last .chat-message-content {
    box-shadow: none !important;
}

/* Nur Sprachmemo(s), kein Text/Antwort/Umfrage: äußere Bubble weglassen — nur .chat-message-voice-Pill */
.chat-message-bot .chat-message-content.chat-message-content--voice-only,
.chat-message-user .chat-message-content.chat-message-content--voice-only {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    gap: 0;
    border-radius: 0 !important;
    color: inherit;
}

.chat-message-bot:not(.chat-message-grouped) .chat-message-content.chat-message-content--voice-only,
.chat-message-user:not(.chat-message-grouped) .chat-message-content.chat-message-content--voice-only,
.chat-message-bot.chat-message-middle-grouped .chat-message-content.chat-message-content--voice-only,
.chat-message-user.chat-message-middle-grouped .chat-message-content.chat-message-content--voice-only,
.chat-message-bot.chat-message-last-in-group .chat-message-content.chat-message-content--voice-only,
.chat-message-user.chat-message-last-in-group .chat-message-content.chat-message-content--voice-only,
.chat-message-user.chat-message-last-before-system .chat-message-content.chat-message-content--voice-only,
.chat-message-bot.chat-message-last-before-system .chat-message-content.chat-message-content--voice-only,
.chat-message-user.chat-message-first-after-system .chat-message-content.chat-message-content--voice-only,
.chat-message-bot.chat-message-first-after-system .chat-message-content.chat-message-content--voice-only {
    border-bottom-left-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
    border-top-left-radius: 0 !important;
    border-top-right-radius: 0 !important;
}

.chat-message-time-wrap {
    display: flex;
    align-items: center;
    gap: 4px;
    opacity: 0;
    transition: opacity 0.2s ease var(--kinma-chat-meta-hover-reveal-delay);
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    z-index: 1;
}

/* Direkt an der Bubble (nicht fix -56px von der ganzen Nachrichtenzeile) */
.chat-message-bot .chat-message-time-wrap {
    left: 100%;
    right: auto;
    margin-left: 8px;
}

.chat-message-user .chat-message-time-wrap {
    right: 100%;
    left: auto;
    margin-right: 8px;
    flex-direction: row-reverse;
}

.chat-message:has(.chat-message-content:hover) .chat-message-time-wrap {
    opacity: 1;
}

.chat-message-time {
    font-size: 11px;
    white-space: nowrap;
    color: rgba(26, 26, 26, 0.6);
}

/* Uhrzeit + Zustellstatus unten in der Bubble; Desktop: Uhrzeit nur bei Hover über die Zeile */
.chat-message-content-meta {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 8px;
    margin-top: 4px;
    width: auto;
    max-width: 100%;
    box-sizing: border-box;
}

.chat-message-user .chat-message-content-meta {
    justify-content: flex-end;
    flex-wrap: nowrap;
    gap: 6px;
    width: auto;
    max-width: 100%;
    align-self: flex-end;
    box-sizing: border-box;
}

.chat-message-user .chat-message-content-meta .chat-message-time-inline,
.chat-message-user .chat-message-content-meta .chat-message-delivery-footer {
    flex-shrink: 0;
}

.chat-message-bot .chat-message-content-meta {
    justify-content: flex-start;
    flex-wrap: nowrap;
    gap: 6px;
    width: auto;
    max-width: 100%;
    align-self: flex-start;
    box-sizing: border-box;
}

.chat-message-bot .chat-message-content-meta .chat-message-time-inline {
    flex-shrink: 0;
}

.chat-message-user .chat-message-content.chat-message-delivery--inline .chat-message-content-meta {
    margin-top: 0;
    flex-shrink: 0;
    flex-wrap: nowrap;
}

.chat-message-content-meta .chat-message-delivery-footer {
    margin-top: 0;
}

.chat-message-content-meta--typing {
    margin-top: 6px;
}

.chat-message-time-inline--always,
.chat-message-content-meta--typing .chat-message-time-inline {
    opacity: 1 !important;
    max-width: none !important;
    overflow: visible !important;
}

.chat-message-time-inline--always .chat-message-time,
.chat-message-content-meta--typing .chat-message-time-inline .chat-message-time {
    visibility: visible !important;
    opacity: 1 !important;
}

@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
    @supports (interpolate-size: allow-keywords) {
        .chat-messages,
        #chatMessages {
            interpolate-size: allow-keywords;
        }
    }

    #chatMessages > .chat-message:not(.chat-message-history-item):has(.chat-message-content:hover) {
        --kinma-chat-meta-hover-reveal-delay: var(--kinma-chat-meta-hover-reveal-wait);
    }

    #chatMessages > .chat-message:not(.chat-message-history-item):not(:has(.chat-message-content:hover)) {
        --kinma-chat-meta-hover-reveal-delay: 0s;
    }

    /*
     * Desktop: Meta-Zeile (Zeit) ein-/ausklappen.
     * Vertikal: max-height auf .chat-message-time-inline.
     * Horizontal: grid-template-columns 0fr → 1fr auf .chat-message-content-meta (zuverlässige Interpolation;
     * max-width: 0 → min(22rem,100%) animiert in vielen Engines nicht sichtbar).
     */
    .chat-message-user:not(.chat-message-history-item)
        .chat-message-content:has(.chat-message-content-meta)
        .chat-message-time-inline:not(.chat-message-time-inline--always) {
        max-height: 0;
        min-width: 0;
        overflow: hidden;
        opacity: 0;
        margin: 0;
        padding: 0;
        flex-shrink: 1;
        min-height: 0;
        transition: none;
        pointer-events: none;
    }

    .chat-message.chat-message-user:not(:has(.chat-message-content:hover)):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        display: grid;
        grid-template-columns: 0fr;
        justify-items: end;
        margin-top: 0;
        min-height: 0;
        min-width: 0;
        max-width: min(22rem, 100%);
        overflow: hidden;
        transition: none;
    }

    .chat-message.chat-message-user:not(:has(.chat-message-content:hover)):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing)
        > .chat-message-time-inline:not(.chat-message-time-inline--always) {
        min-width: 0;
        overflow: hidden;
    }

    .chat-message-user:not(.chat-message-history-item):has(.chat-message-content:hover)
        .chat-message-content:has(.chat-message-content-meta)
        .chat-message-time-inline:not(.chat-message-time-inline--always) {
        max-height: 2.75rem;
        opacity: 1;
        min-height: 0;
        transition:
            max-height var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            opacity var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
        pointer-events: auto;
    }

    .chat-message.chat-message-user:has(.chat-message-content:hover):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        display: grid;
        grid-template-columns: 1fr;
        justify-items: end;
        margin-top: 4px;
        max-width: min(22rem, 100%);
        /* hidden: vermeidet Reflow/Paint-Sprünge mit animierendem grid-template-columns (visible wechselt sofort). */
        overflow: hidden;
        transition:
            margin-top var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            grid-template-columns var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    .chat-message-bot:not(.chat-message-history-item)
        .chat-message-content-meta
        .chat-message-time-inline:not(.chat-message-time-inline--always) {
        max-height: 0;
        min-width: 0;
        overflow: hidden;
        opacity: 0;
        margin: 0;
        padding: 0;
        flex-shrink: 1;
        min-height: 0;
        transition: none;
        pointer-events: none;
    }

    .chat-message.chat-message-bot:not(:has(.chat-message-content:hover)):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        display: grid;
        grid-template-columns: 0fr;
        justify-items: start;
        margin-top: 0;
        min-height: 0;
        max-width: min(22rem, 100%);
        min-width: 0;
        overflow: hidden;
        transition: none;
    }

    .chat-message.chat-message-bot:not(:has(.chat-message-content:hover)):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing)
        > .chat-message-time-inline:not(.chat-message-time-inline--always) {
        min-width: 0;
        overflow: hidden;
    }

    .chat-message-bot:not(.chat-message-history-item):has(.chat-message-content:hover)
        .chat-message-content-meta
        .chat-message-time-inline:not(.chat-message-time-inline--always) {
        max-height: 2.75rem;
        opacity: 1;
        min-height: 0;
        transition:
            max-height var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            opacity var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
        pointer-events: auto;
    }

    .chat-message.chat-message-bot:has(.chat-message-content:hover):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        display: grid;
        grid-template-columns: 1fr;
        justify-items: start;
        margin-top: 4px;
        max-width: min(22rem, 100%);
        overflow: hidden;
        transition:
            margin-top var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            grid-template-columns var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }
}

/*
 * Nach erstem Paint setzt JS data-chat-meta-tx-ready="1" auf #chatMessages:
 * Meta ein-/ausblenden und Bubble-Breite animieren (auch beim Hover-Verlassen),
 * ohne „Schrumpf“ beim ersten Laden.
 * border-radius wird hier nicht animiert: --kinma-protrude-* folgt der Breite pro Frame (JS).
 */
@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-user:not(.chat-message-history-item)
        .chat-message-content:has(.chat-message-content-meta)
        .chat-message-time-inline:not(.chat-message-time-inline--always) {
        transition:
            max-height var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            opacity var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message.chat-message-user:not(:has(.chat-message-content:hover)):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        transition:
            margin-top var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            grid-template-columns var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-bot:not(.chat-message-history-item)
        .chat-message-content-meta
        .chat-message-time-inline:not(.chat-message-time-inline--always) {
        transition:
            max-height var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            opacity var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message.chat-message-bot:not(:has(.chat-message-content:hover)):not(.chat-message-history-item)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        transition:
            margin-top var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            grid-template-columns var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-user:not(.chat-message-history-item)
        .chat-message-content:has(.chat-message-content-meta) {
        transition:
            padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            gap var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-bot:not(.chat-message-history-item)
        .chat-message-content:has(.chat-message-content-meta):not(:has(> .chat-message-quote-stack)),
    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-bot:not(.chat-message-history-item)
        .chat-message-content:has(> .chat-message-quote-stack):has(.chat-message-content-meta) {
        transition:
            padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            gap var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-user:not(.chat-message-history-item)
        .chat-message-content:has(.chat-message-content-meta)
        .chat-message-content-meta {
        /* Kein width in transition: auto/% interpoliert nicht → Ruckeln beim Hover-Eintritt. */
        transition:
            margin-top var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            grid-template-columns var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message-bot:not(.chat-message-history-item)
        .chat-message-content:has(.chat-message-content-meta)
        .chat-message-content-meta {
        transition:
            margin-top var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay),
            grid-template-columns var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
                var(--kinma-chat-meta-hover-reveal-delay);
    }

    /* Meta-Zeile (Datum/Uhrzeit) an der Innenkante der Bubble, nicht zentriert */
    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message.chat-message-user:not(.chat-message-history-item):has(.chat-message-content:hover)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        align-self: flex-end;
        max-width: min(22rem, 100%);
        justify-items: end;
    }

    #chatMessages[data-chat-meta-tx-ready="1"].chat-messages
        .chat-message.chat-message-bot:not(.chat-message-history-item):has(.chat-message-content:hover)
        .chat-message-content:not(:has(.chat-message-delivery-footer)):has(.chat-message-time-inline:not(.chat-message-time-inline--always))
        .chat-message-content-meta:not(.chat-message-content-meta--typing) {
        align-self: flex-start;
        max-width: min(22rem, 100%);
        justify-items: start;
    }
}

@media (max-width: 1024px) {
    /* 5-Minuten-Cluster: Uhrzeit nur auf der letzten Nachricht der Gruppe (cluster-last / cluster-only) */
    .chat-message.chat-message-cluster-first:not(.chat-message-history-item)
        .chat-message-content-meta:not(.chat-message-content-meta--typing):not(:has(.chat-message-delivery-footer)),
    .chat-message.chat-message-cluster-middle:not(.chat-message-history-item)
        .chat-message-content-meta:not(.chat-message-content-meta--typing):not(:has(.chat-message-delivery-footer)) {
        display: none !important;
    }

    .chat-message .chat-message-content-meta .chat-message-time-inline {
        max-width: none !important;
        overflow: visible !important;
        opacity: 1 !important;
    }

    .chat-message .chat-message-content-meta .chat-message-time-inline .chat-message-time {
        opacity: 1 !important;
    }

    .chat-message-user .chat-message-content-meta {
        align-self: flex-end !important;
        justify-content: flex-end !important;
        width: auto !important;
    }

    .chat-message-bot .chat-message-content-meta {
        align-self: flex-start !important;
        justify-content: flex-start !important;
        width: auto !important;
    }

    .chat-message-user .chat-message-content-meta .chat-message-time {
        text-align: right;
    }

    .chat-message-bot .chat-message-content-meta .chat-message-time {
        text-align: left;
    }
}

.chat-popup.ai-mode .chat-message-bot .chat-message-content-meta .chat-message-time {
    color: rgba(255, 255, 255, 0.78);
}

.chat-popup.ai-mode .chat-message-user .chat-message-content-meta .chat-message-time {
    color: rgba(26, 26, 26, 0.55);
}

.chat-message-bot .chat-message-content-meta .chat-message-time {
    color: var(--kinma-incoming-fg-muted, rgba(255, 255, 255, 0.72));
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-content-meta {
    margin-top: 6px;
    padding-left: 2px;
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack) > .chat-message-content-meta .chat-message-time {
    color: rgba(255, 255, 255, 0.72);
}

.chat-message-status-wrap {
    display: flex;
    align-items: center;
}

.chat-message-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #6b7280;
}

.chat-message-status-sent,
.chat-message-status-delivered {
    color: #6b7280;
}

.chat-message-status-read {
    color: #0ea5e9;
}

/* Outgoing: delivery ticks — 1 text line = beside message; 2+ lines = full-width text, ticks below */
.chat-message-user .chat-message-content {
    position: relative;
    padding: 10px 10px 10px 14px;
    transition:
        padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay);
}

.chat-message-bot .chat-message-content {
    position: relative;
    padding: 10px 14px 10px 10px;
    transition:
        padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay);
}

/* Bubble nur so breit wie Inhalt: Meta (Zeit+Häkchen) nicht mit width:100% aufblasen */
/* Kein width/max-width/gap-Transition im Default: sonst „Schrumpfen“ beim ersten Paint (Meta startet eingeklappt). */
.chat-message-user .chat-message-content:has(.chat-message-content-meta) {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 4px;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
    transition:
        padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay),
        gap var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay);
}

.chat-message-bot .chat-message-content:has(.chat-message-content-meta) {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
    transition:
        padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay),
        gap var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay);
}

.chat-message-bot .chat-message-content:has(> .chat-message-quote-stack):has(.chat-message-content-meta) {
    gap: 8px;
}

.chat-message-user .chat-message-content:has(.chat-message-content-meta) .chat-message-content-meta {
    transition: none;
}

.chat-message-bot .chat-message-content:has(.chat-message-content-meta) .chat-message-content-meta {
    transition: none;
}

.chat-message-bot:not(.chat-message-history-item) .chat-message-content:has(.chat-message-content-meta):not(:has(> .chat-message-quote-stack)),
.chat-message-bot:not(.chat-message-history-item) .chat-message-content:has(> .chat-message-quote-stack):has(.chat-message-content-meta) {
    transition:
        padding var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay),
        gap var(--kinma-chat-meta-reveal-duration) var(--kinma-chat-meta-reveal-ease)
            var(--kinma-chat-meta-hover-reveal-delay);
}

.chat-message-user .chat-message-content .chat-message-body {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 0;
    flex: 1 1 auto;
}

/* Eine Zeile (Pill): Text zum Außenrand der Bubble; mehrzeilig: normal links (start) */
.chat-message-user .chat-message-content.chat-message-pill .chat-message-body {
    text-align: end;
}

.chat-message-user .chat-message-content:not(.chat-message-pill) .chat-message-body {
    text-align: start;
}

.chat-message-user .chat-message-content:has(.chat-message-content-meta) .chat-message-body {
    flex: 0 1 auto;
}

.chat-message-user .chat-message-content.chat-message-pill {
    padding: 8px 12px 8px 16px;
}

.chat-message-bot .chat-message-content.chat-message-pill {
    padding: 8px 16px 8px 12px;
}

@media (max-width: 1024px) {
    /* Outgoing normal messages: delivery tick visually closer to the right edge */
    .chat-message-user .chat-message-content {
        padding-right: 8px;
    }
    .chat-message-user .chat-message-content.chat-message-pill {
        padding-right: 10px;
    }

    /* Incoming: Zeit näher an der linken (Avatar-)Kante */
    .chat-message-bot .chat-message-content {
        padding-left: 8px;
    }
    .chat-message-bot .chat-message-content.chat-message-pill {
        padding-left: 10px;
    }

    /* Reference/reply quote block: more usable width on mobile */
    .chat-message-user .chat-message-outgoing-stack,
    .chat-message-bot .chat-message-incoming-stack {
        max-width: 100%;
    }
    .chat-message:has(.chat-message-quote-stack),
    .chat-message.chat-message-user.chat-message-user-has-outgoing-quote,
    .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote {
        max-width: 96%;
    }
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-above {
        padding-right: 10px;
    }
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-above {
        padding-left: 10px;
    }
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-primary,
    .chat-message-user .chat-message-outgoing-stack .chat-message-quote-context {
        border-top-left-radius: var(--kinma-quote-card-r, 20px) !important;
        border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
        border-top-right-radius: 0 !important;
        border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
    }

    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-primary,
    .chat-message-bot .chat-message-incoming-stack .chat-message-quote-context {
        border-top-left-radius: 0 !important;
        border-bottom-left-radius: var(--kinma-quote-card-r, 20px) !important;
        border-top-right-radius: var(--kinma-quote-card-r, 20px) !important;
        border-bottom-right-radius: var(--kinma-quote-card-r, 20px) !important;
    }

}

.chat-message-user .chat-message-content.chat-message-pill:has(.chat-message-content-meta) {
    padding-bottom: 8px;
}

.chat-message-bot .chat-message-content.chat-message-pill:has(.chat-message-content-meta) {
    padding-bottom: 8px;
}

.chat-message-user .chat-message-content.chat-message-pill:has(.chat-message-content-meta) .chat-message-body {
    width: fit-content;
    max-width: 100%;
    align-self: flex-end;
}

@media (hover: hover) and (pointer: fine) and (min-width: 1025px) {
    .chat-message.chat-message-user:not(:has(.chat-message-content:hover)) .chat-message-content.chat-message-pill:has(.chat-message-content-meta) {
        padding-bottom: 8px;
        gap: 2px;
    }

    .chat-message.chat-message-bot:not(:has(.chat-message-content:hover)) .chat-message-content.chat-message-pill:has(.chat-message-content-meta) {
        padding-bottom: 8px;
        gap: 2px;
    }
}

/* Default: kein Abstand — Ausnahmen: >5 Min, Seitenwechsel, Zitate, Systemnachrichten */
#chatMessages .chat-message + .chat-message:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break):not(.chat-message-system) {
    margin-top: 0 !important;
}

#chatMessages .chat-message.chat-message-system + .chat-message.chat-message-system {
    margin-top: 10px !important;
}

#chatMessages .chat-message.chat-message-system + .chat-message:not(.chat-message-system):not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMessages .chat-message:not(.chat-message-system) + .chat-message.chat-message-system {
    margin-top: 12px !important;
}

#chatMessages .chat-date-separator + .chat-message.chat-message-system {
    margin-top: 8px !important;
}

/* >5 Min seit vorheriger Nachricht (eingehend + ausgehend) */
#chatMessages .chat-message + .chat-message.chat-message-time-cluster-start,
#chatMain .chat-messages > .chat-message + .chat-message.chat-message-time-cluster-start,
.chat-popup.active #chatMain > .chat-messages > .chat-message + .chat-message.chat-message-time-cluster-start {
    margin-top: 16px !important;
}

/* Wechsel links/rechts (anderer Absender), auch innerhalb von 5 Min */
#chatMessages .chat-message + .chat-message.chat-message-after-side-break:not(.chat-message-time-cluster-start) {
    margin-top: 10px !important;
}

/* Abstand zwischen Reply-Sammlungen (auch direkt hintereinander im 5-Min-Cluster) */
#chatMessages .chat-message + .chat-message:has(.chat-message-quote-stack),
#chatMessages .chat-message + .chat-message.chat-message-user.chat-message-user-has-outgoing-quote,
#chatMain .chat-messages > .chat-message + .chat-message.chat-message-user.chat-message-user-has-outgoing-quote,
#chatMessages .chat-message.chat-message-user-has-outgoing-quote + .chat-message,
#chatMessages .chat-message.chat-message-user-has-outgoing-quote + .chat-message.chat-message-user-has-outgoing-quote,
#chatMessages .chat-message + .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote,
#chatMain .chat-messages > .chat-message + .chat-message.chat-message-bot.chat-message-bot-has-incoming-quote,
#chatMessages .chat-message.chat-message-bot-has-incoming-quote + .chat-message,
#chatMessages .chat-message.chat-message-bot-has-incoming-quote + .chat-message.chat-message-bot-has-incoming-quote {
    margin-top: 20px !important;
}

/*
 * Reply im 5-Min-Cluster unter beliebiger Vorgänger-Nachricht (Text, Bild, Umfrage, Reply, …):
 * kein 20px-Sprung — Abstand wird per JS gemessen (--kinma-reply-cluster-chain-gap), Faden ::before überbrückt.
 */
#chatMessages .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMain .chat-messages > .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
.chat-popup.active #chatMain > .chat-messages > .chat-message.chat-message-user.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMessages .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMain .chat-messages > .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
.chat-popup.active #chatMain > .chat-messages > .chat-message.chat-message-bot.chat-message-reply-thread-chain:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMessages .chat-message.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMain .chat-messages > .chat-message.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
.chat-popup.active #chatMain > .chat-messages > .chat-message.chat-message-bot-has-incoming-quote
    + .chat-message.chat-message-bot-has-incoming-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMessages .chat-message.chat-message-bot:has(.chat-message-incoming-stack .chat-message-quote-above)
    + .chat-message.chat-message-bot:has(.chat-message-incoming-stack .chat-message-quote-above):not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMain .chat-messages > .chat-message.chat-message-bot:has(.chat-message-incoming-stack .chat-message-quote-above)
    + .chat-message.chat-message-bot:has(.chat-message-incoming-stack .chat-message-quote-above):not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMessages .chat-message.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMain .chat-messages > .chat-message.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
.chat-popup.active #chatMain > .chat-messages > .chat-message.chat-message-user-has-outgoing-quote
    + .chat-message.chat-message-user-has-outgoing-quote:not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMessages .chat-message.chat-message-user:has(.chat-message-outgoing-stack .chat-message-quote-above)
    + .chat-message.chat-message-user:has(.chat-message-outgoing-stack .chat-message-quote-above):not(.chat-message-time-cluster-start):not(.chat-message-after-side-break),
#chatMain .chat-messages > .chat-message.chat-message-user:has(.chat-message-outgoing-stack .chat-message-quote-above)
    + .chat-message.chat-message-user:has(.chat-message-outgoing-stack .chat-message-quote-above):not(.chat-message-time-cluster-start):not(.chat-message-after-side-break) {
    margin-top: 0 !important;
}

/* Ausgehend / eingehend: Faden-Länge für Reply-Kette (siehe ::before-Regeln oben + kinmaApplyReplyClusterThreadBridges) */

.chat-message-user .chat-message-content.chat-message-delivery--inline:has(.chat-message-delivery-footer) {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: flex-end;
    gap: 6px;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
}

.chat-message-user .chat-message-content.chat-message-delivery--inline .chat-message-body {
    flex: 0 1 auto;
    width: fit-content;
    max-width: 100%;
    min-width: 0;
}

.chat-message-delivery-footer {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    line-height: 0;
    pointer-events: auto;
}

.chat-message-user .chat-message-content:has(.chat-message-content-meta) .chat-message-delivery-footer {
    position: static;
    align-self: flex-end;
    margin-top: 0;
}

.chat-message-user .chat-message-content.chat-message-delivery--inline .chat-message-delivery-footer {
    margin-top: 0;
    flex-shrink: 0;
}

/* Pure attachment messages: no outer chat bubble, attachment card/media is the message. */
.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) {
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    overflow: visible;
    border-radius: 0 !important;
}

.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-message-body {
    gap: 0;
    width: fit-content;
    max-width: 100%;
}

.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-message-attachments {
    margin: 0;
    display: block;
    position: relative;
    width: fit-content;
    max-width: 100%;
}

.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-attachment-image,
.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-attachment-video,
.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-message-attachment,
.chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-attachment-document-preview {
    margin-top: 0 !important;
}

.chat-message-user .chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) {
    position: relative;
    width: fit-content;
    max-width: 100%;
}

.chat-message-user .chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) .chat-message-delivery-footer {
    position: absolute;
    right: 10px;
    bottom: 10px;
    margin-top: 0;
    padding: 4px 6px;
    border-radius: 999px;
    background: rgba(26, 26, 26, 0.45);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.chat-message-user .chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) .chat-message-delivery-status {
    color: rgba(255, 255, 255, 0.95);
}

.chat-message-user .chat-message-content:has(.chat-message-attachments):not(:has(.chat-message-text)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) .chat-message-delivery-status--read {
    color: #7dd3fc;
}

/* Pure image messages: no bubble frame, image itself is the message. */
.chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) {
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    overflow: visible;
}

.chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-message-body {
    gap: 0;
}

.chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-message-attachments {
    display: block;
}

.chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-attachment-image {
    margin: 0;
    border-radius: 18px;
    overflow: hidden;
    position: relative;
}

.chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)) .chat-attachment-img {
    border-radius: 18px;
    display: block;
}

.chat-message-user .chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) {
    position: relative;
}

.chat-message-user .chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) .chat-message-delivery-footer {
    position: absolute;
    right: 10px;
    bottom: 10px;
    margin-top: 0;
    padding: 4px 6px;
    border-radius: 999px;
    background: rgba(26, 26, 26, 0.45);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}

.chat-message-user .chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) .chat-message-delivery-status {
    color: rgba(255, 255, 255, 0.95);
}

.chat-message-user .chat-message-content:has(.chat-attachment-image):not(:has(.chat-message-text)):not(:has(.chat-message-attachment)):not(:has(.chat-message-voice)):not(:has(.chat-message-poll)):has(.chat-message-delivery-footer) .chat-message-delivery-status--read {
    color: #7dd3fc;
}

.chat-message-delivery-status {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #6b7280;
}

.chat-message-delivery-status--read {
    color: #0ea5e9;
}

.chat-message-delivery-double {
    position: relative;
    display: inline-flex;
    align-items: center;
    width: 18px;
    height: 12px;
}

.chat-message-delivery-double--read {
    color: #0ea5e9;
}

.chat-message-delivery-icon--shift {
    position: absolute;
    left: 5px;
    top: 0;
}

.chat-message-bot .chat-message-time-wrap .chat-message-time {
    color: rgba(255, 255, 255, 0.72);
}

.chat-message-user .chat-message-time-wrap .chat-message-time {
    color: rgba(26, 26, 26, 0.6);
}

.chat-message-edited {
    font-size: 11px;
    color: #6c757d;
    cursor: pointer;
    text-decoration: underline;
    text-decoration-style: dotted;
    transition: color 0.2s ease;
}

.chat-message-edited:hover {
    color: #1a1a1a;
}

.chat-message-bot .chat-message-content .chat-message-edited {
    color: rgba(255, 255, 255, 0.65);
}

.chat-message-bot .chat-message-content .chat-message-edited:hover {
    color: #ffffff;
}

.chat-message-edit-btn {
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    padding: 0;
    border: none;
    background: #ffffff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    /* opacity folgt Zeilen-Hover-Verzögerung; Rest sofort beim Hover über den Button */
    transition:
        opacity 0.2s ease var(--kinma-chat-meta-hover-reveal-delay),
        color 0.2s ease,
        background 0.2s ease,
        box-shadow 0.2s ease,
        transform 0.2s ease;
    border-radius: 50%;
    color: #6c757d;
    flex-shrink: 0;
    align-self: center;
    order: -1;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.chat-message-user:has(.chat-message-content:hover, .chat-message-edit-btn:hover) .chat-message-edit-btn {
    opacity: 1;
}

.chat-message-edit-btn:hover {
    color: #1a1a1a;
    background: #ffffff;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
    transform: scale(1.05);
}

.chat-message-edit-btn svg {
    width: 16px;
    height: 16px;
}

.chat-message-editing {
    background: #f8f9fa !important;
}

.chat-message-editing-indicator {
    font-size: 11px;
    color: #6c757d;
    font-style: italic;
    margin-bottom: 8px;
}

.chat-message-edit-input {
    width: 100%;
    padding: 8px 12px;
    border: 1px solid #dee2e6;
    border-radius: 8px;
    font-size: 14px;
    font-family: inherit;
    resize: vertical;
    min-height: 60px;
    margin-bottom: 8px;
}

.chat-message-edit-input:focus {
    outline: none;
    border-color: #1a1a1a;
}

.chat-message-edit-actions {
    display: flex;
    gap: 8px;
    justify-content: flex-end;
}

.chat-message-edit-save,
.chat-message-edit-cancel {
    padding: 6px 16px;
    border: none;
    border-radius: 6px;
    font-size: 13px;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.2s ease;
}

.chat-message-edit-save {
    background: #1a1a1a;
    color: #ffffff;
}

.chat-message-edit-save:hover {
    background: #1a1a1a;
}

.chat-message-edit-cancel {
    background: #f8f9fa;
    color: #6c757d;
    border: 1px solid #dee2e6;
}

.chat-message-edit-cancel:hover {
    background: #e9ecef;
    color: #1a1a1a;
}

.chat-message-history-placeholder {
    /* Ensure the placeholder doesn't interfere with message alignment */
    display: flex;
    flex-direction: column;
    gap: 2px;
    margin-top: -2px;
    margin-bottom: 2px;
}

.chat-message-history-load-more {
    text-align: center;
    padding: 8px 12px 10px;
    font-size: 13px;
    font-weight: 500;
    color: #0d6efd;
    cursor: pointer;
    user-select: none;
    border-radius: 8px;
    transition: background 0.15s ease, color 0.15s ease;
}

.chat-message-history-load-more:hover {
    text-decoration: underline;
    background: rgba(13, 110, 253, 0.06);
}

.chat-message-history-load-more:focus-visible {
    outline: 2px solid #0d6efd;
    outline-offset: 2px;
}

.chat-message-history-load-more[aria-busy='true'] {
    opacity: 0.55;
    pointer-events: none;
}

body.dark-mode .chat-message-history-load-more {
    color: #6ea8fe;
}

body.dark-mode .chat-message-history-load-more:hover {
    background: rgba(110, 168, 254, 0.08);
}

.chat-message-history-item {
    opacity: 0;
    animation: slideUpFromMessage 0.6s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    transform-origin: bottom center;
    margin-bottom: -4px;
    /* Inherit all base styles from .chat-message - it already has display: flex, max-width: 75%, etc. */
}

.chat-message-history-item:hover {
    opacity: 0.7 !important;
}

/* Nur frühere Versionen (Bearbeitungs-Historie): vollständig abgerundet — nicht die aktuelle Nachricht */
.chat-message-history-item .chat-message-content {
    border-radius: 9999px !important;
    border-top-left-radius: 9999px !important;
    border-top-right-radius: 9999px !important;
    border-bottom-left-radius: 9999px !important;
    border-bottom-right-radius: 9999px !important;
}

/* Historie: Uhrzeit in der Bubble, immer sichtbar */
.chat-message-history-item .chat-message-time-inline {
    opacity: 1 !important;
    max-width: none !important;
    overflow: visible !important;
}

.chat-message-history-item .chat-message-content-meta .chat-message-time {
    visibility: visible !important;
    opacity: 1 !important;
}

.chat-message-history-item .chat-message-time {
    white-space: nowrap;
    font-size: 10px;
}

.chat-message-history-avatar-spacer {
    /* Match exact size of normal avatar */
    width: var(--chat-message-line-avatar-size, 30px);
    height: var(--chat-message-line-avatar-size, 30px);
    border-radius: 50%;
    flex-shrink: 0;
    /* Make it invisible but maintain layout space */
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    /* Ensure it maintains its size and spacing */
    min-width: var(--chat-message-line-avatar-size, 30px);
    min-height: var(--chat-message-line-avatar-size, 30px);
    margin: 0;
    padding: 0;
}

.chat-message-history-error {
    font-size: 12px;
    color: #dc3545;
    text-align: center;
    padding: 12px;
}

.chat-message-history-empty {
    font-size: 12px;
    color: #9ca3af;
    text-align: center;
    padding: 12px;
    font-style: italic;
}

.chat-input-container {
    padding: 16px 20px;
    border-top: 1px solid #ffffff;
    display: flex;
    align-items: center;
    position: relative;
}

/*
 * Composer file inputs: kein display:none — Mobile-Safari / einige Browser blockieren programmatisches .click()
 * auf komplett versteckten file inputs. Visuell unsichtbar, positioniert im relative-Eltern-Container.
 */
.kinma-chat-ai-file-input--sr-only,
.kinma-chat-composer-file-input--sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px 0 0 -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    border: 0;
    opacity: 0.01;
    z-index: 0;
}

/* KI-Input nur im KI-Modus klickbar (verhindert Treffer auf unsichtbarem Element im Family-Chat) */
.chat-popup:not(.ai-mode) .kinma-chat-ai-file-input--sr-only {
    pointer-events: none;
}

.chat-input-wrapper {
    position: relative;
    flex: 1;
    display: flex;
    align-items: center;
    background: #ffffff;
    border: 1.5px solid #e5e7eb;
    border-radius: 28px;
    padding: 4px;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08);
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.chat-input-wrapper:hover {
    border-color: #d1d5db;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.1);
}

.chat-input-wrapper:focus-within {
    border-color: #1a1a1a;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
    transform: translateY(-1px);
}

.chat-popup.ai-mode .chat-input-wrapper:focus-within {
    border-color: #6366f1;
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.25);
}

.chat-input {
    width: 100%;
    padding: 12px 50px 12px 92px;
    border: none;
    border-radius: 24px;
    font-size: 14px;
    outline: none;
    background: transparent;
    color: #1a1a1a;
    transition: all 0.2s ease;
    overflow: hidden;
    overflow-y: hidden;
    overflow-x: hidden;
}

.chat-input:placeholder-shown {
    overflow: hidden !important;
    overflow-y: hidden !important;
    overflow-x: hidden !important;
}

.chat-input::placeholder {
    color: #9ca3af;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.chat-input:focus {
    outline: none;
}

.chat-camera-inline-btn {
    position: absolute;
    left: 8px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: transparent;
    color: #6b7280;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
    z-index: 10;
    pointer-events: auto;
}

.chat-attachment-btn {
    position: absolute;
    left: 48px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: transparent;
    color: #6b7280;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
    z-index: 10;
    pointer-events: auto;
}

.chat-input-wrapper.recording .chat-attachment-btn,
.chat-input-wrapper.recording .chat-camera-inline-btn,
#chatInputWrapper.recording .chat-attachment-btn,
#chatInputWrapper.recording .chat-camera-inline-btn {
    display: none !important;
    pointer-events: none !important;
}

.chat-input-wrapper:not(.recording) .chat-attachment-btn,
.chat-input-wrapper:not(.recording) .chat-camera-inline-btn,
#chatInputWrapper:not(.recording) .chat-attachment-btn,
#chatInputWrapper:not(.recording) .chat-camera-inline-btn {
    display: flex !important;
    pointer-events: auto !important;
}

.chat-camera-inline-btn:hover {
    background: #f3f4f6;
    color: #1a1a1a;
    transform: scale(1.05);
}

.chat-camera-inline-btn:active {
    transform: scale(0.95);
}

.chat-attachment-btn:hover {
    background: #f3f4f6;
    color: #1a1a1a;
    transform: scale(1.05);
}

.chat-attachment-btn:active {
    transform: scale(0.95);
}

.chat-send-btn {
    position: absolute;
    right: 6px;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #1a1a1a 0%, #1a1a1a 100%);
    color: #ffffff;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
    flex-shrink: 0;
    z-index: 1;
    box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.chat-send-btn:hover {
    transform: scale(1.05);
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.15);
}

.chat-send-btn:active {
    transform: scale(0.95);
}

.chat-send-btn:disabled {
    background: #d1d5db;
    color: #9ca3af;
    cursor: not-allowed;
    box-shadow: none;
}

.chat-send-btn:disabled:hover {
    transform: none;
    box-shadow: none;
}

.chat-popup.ai-mode .chat-send-btn {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%);
}

.chat-popup.ai-mode .chat-send-btn:hover {
    background: linear-gradient(135deg, #4f46e5 0%, #4338ca 100%);
}

.chat-popup.ai-mode .chat-send-btn:disabled {
    background: #ddd6fe;
    color: #9ca3af;
}

.chat-popup.ai-mode .chat-input-container {
    background: #ffffff;
    border-top-color: #e9ecef;
}

/* KI: Vorschau-Streifen wie Family — über der Eingabezeile (nicht daneben) */
.chat-popup.ai-mode #chatMain > .chat-input-container {
    flex-direction: column !important;
    align-items: stretch !important;
    align-content: stretch !important;
}

.chat-popup.ai-mode #chatMain .chat-file-preview-area {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    flex-shrink: 0;
}

.chat-popup.ai-mode #chatMain .chat-input-bar-row {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    flex-shrink: 0;
}

.chat-popup.ai-mode .chat-input-wrapper {
    background: #ffffff;
    border-color: rgba(99, 102, 241, 0.35);
}

.chat-popup.ai-mode .chat-voice-btn {
    color: #6366f1;
}

.chat-popup.ai-mode .chat-voice-btn:hover {
    background: rgba(99, 102, 241, 0.12);
    color: #4f46e5;
}

.chat-popup.ai-mode .chat-input-wrapper.ai-dictation-listening {
    border-color: #6366f1;
    box-shadow: 0 0 0 3px rgba(99, 102, 241, 0.2);
}

.chat-popup.ai-mode .chat-voice-btn.ai-dictation-active {
    color: #ffffff !important;
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    box-shadow: 0 2px 12px rgba(99, 102, 241, 0.45);
    animation: kinmaAiDictationPulse 1.4s ease-in-out infinite;
}

.chat-popup.ai-mode .chat-input-wrapper.ai-dictation-processing {
    border-color: rgba(99, 102, 241, 0.45);
    box-shadow: 0 0 0 2px rgba(99, 102, 241, 0.12);
}

.chat-popup.ai-mode .chat-voice-btn.ai-dictation-processing {
    opacity: 0.75;
    cursor: wait;
    animation: none;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.25) !important;
}

.chat-voice-btn .voice-dictation-active-icon {
    display: none;
    align-items: center;
    justify-content: center;
}

.chat-voice-btn.ai-dictation-active .voice-mic-icon {
    display: none !important;
}

.chat-voice-btn.ai-dictation-active .voice-dictation-active-icon {
    display: flex !important;
}

@keyframes kinmaAiDictationPulse {
    0%,
    100% {
        box-shadow: 0 2px 12px rgba(99, 102, 241, 0.45);
    }
    50% {
        box-shadow: 0 4px 18px rgba(99, 102, 241, 0.65);
    }
}

/* KI-Modus: äußere Kreise (Anhang / Mikro) — chat-enhancements.css setzt sonst Schwarz mit !important */
.chat-popup.ai-mode .chat-input-bar-row .chat-attachment-btn,
.chat-popup.ai-mode .chat-input-external .chat-attachment-btn {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.35) !important;
}

.chat-popup.ai-mode .chat-input-bar-row .chat-attachment-btn:hover,
.chat-popup.ai-mode .chat-input-external .chat-attachment-btn:hover {
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.45) !important;
}

.chat-popup.ai-mode .chat-input-bar-row .chat-voice-btn:not(.ai-dictation-active),
.chat-popup.ai-mode .chat-input-external .chat-voice-btn:not(.ai-dictation-active) {
    background: linear-gradient(135deg, #6366f1 0%, #4f46e5 100%) !important;
    color: #ffffff !important;
    box-shadow: 0 2px 8px rgba(99, 102, 241, 0.35) !important;
}

.chat-popup.ai-mode .chat-input-bar-row .chat-voice-btn:not(.ai-dictation-active):hover,
.chat-popup.ai-mode .chat-input-external .chat-voice-btn:not(.ai-dictation-active):hover {
    box-shadow: 0 4px 12px rgba(99, 102, 241, 0.45) !important;
}

.chat-send-btn.editing {
    background: #28a745;
}

.chat-send-btn.editing:hover {
    background: #218838;
}

/* Mic: default flex; absolute only for legacy markup (mic inside wrapper). */
.chat-voice-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: transparent;
    color: #6b7280;
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.2s ease;
    flex-shrink: 0;
    z-index: 1;
}

.chat-input-wrapper > .chat-voice-btn {
    position: absolute;
    right: 6px;
}

.chat-voice-btn:hover {
    background: #f3f4f6;
    color: #1a1a1a;
    transform: scale(1.05);
}

.chat-voice-btn:active {
    transform: scale(0.95);
}

.chat-voice-btn .voice-cancel-icon {
    display: none;
}

.chat-voice-btn .voice-cancel-icon[style*="display: block"],
.chat-voice-btn:has(.voice-cancel-icon[style*="display: block"]) {
    color: #dc3545 !important;
    background: rgba(220, 53, 69, 0.1) !important;
}

.chat-voice-btn:has(.voice-cancel-icon[style*="display: block"]):hover {
    background: rgba(220, 53, 69, 0.2) !important;
    color: #c82333 !important;
}

.chat-voice-btn.recording-cancel {
    color: #dc3545 !important;
    background: rgba(220, 53, 69, 0.1) !important;
}

.chat-voice-btn.recording-cancel:hover {
    background: rgba(220, 53, 69, 0.2) !important;
    color: #c82333 !important;
}

.chat-edit-cancel-btn {
    width: 40px;
    height: 40px;
    padding: 0;
    border: none;
    background: #f8f9fa;
    border: 1px solid #dee2e6;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    color: #6c757d;
    transition: all 0.2s ease;
    flex-shrink: 0;
}

.chat-edit-cancel-btn:hover {
    background: #e9ecef;
    color: #1a1a1a;
    border-color: #adb5bd;
}

.chat-message-being-edited {
    opacity: 0.6;
}

.chat-message-being-edited .chat-message-content {
    position: relative;
}

.chat-message-being-edited .chat-message-content::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: rgba(40, 167, 69, 0.1);
    border-radius: inherit;
    pointer-events: none;
    z-index: 1;
}

.chat-send-btn:active {
    transform: scale(0.95);
}

.chat-attachment-quick-access-bar {
    position: absolute;
    bottom: calc(100% + 12px);
    left: 0;
    display: flex;
    flex-direction: column;
    gap: 8px;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all 0.2s ease;
    z-index: 2000;
}

.chat-input-wrapper.has-chat-quick-access.show-chat-quick-access .chat-attachment-quick-access-bar,
.chat-composer-attachment-host.has-chat-quick-access.show-chat-quick-access .chat-attachment-quick-access-bar {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
}

.chat-quick-access-item {
    min-width: 120px;
    height: 40px;
    padding: 0 14px;
    border-radius: 50px;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    gap: 10px;
    background: linear-gradient(135deg, #1a1a1a 0%, #1a1a1a 100%);
    color: #ffffff;
    text-decoration: none;
    transition: all 0.2s ease;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
    border: 2px solid rgba(255, 255, 255, 0.3);
    white-space: nowrap;
    cursor: pointer;
}

.chat-quick-access-item svg {
    width: 18px;
    height: 18px;
    stroke-width: 2;
    stroke: currentColor;
    fill: none;
    flex-shrink: 0;
}

.chat-quick-access-item-label {
    font-size: 13px;
    font-weight: 500;
    color: #ffffff;
    text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
}

.chat-quick-access-item:hover {
    transform: translateY(-2px);
    border-color: rgba(255, 255, 255, 0.6);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    background: linear-gradient(135deg, #1a1a1a 0%, #1a1a1a 100%);
}

.chat-quick-access-item.active {
    transform: translateY(-2px);
    border-color: rgba(255, 255, 255, 0.6);
    filter: brightness(1.2);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
    background: linear-gradient(135deg, #1a1a1a 0%, #1a1a1a 100%);
}

.chat-attachment-btn.quick-access-active {
    filter: brightness(1.3) !important;
    transform: scale(1.05);
    z-index: 2001;
    position: relative;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
    opacity: 1 !important;
}

.chat-input-wrapper.has-chat-quick-access.show-chat-quick-access,
.chat-composer-attachment-host.has-chat-quick-access.show-chat-quick-access {
    position: relative;
    z-index: 2000;
}


.chat-btn-above-family svg {
    width: 24px;
    height: 24px;
}
