/* =========================
   Base
========================= */
html { background-color: #fff; font-size: 16px; }
html, body { height: auto; min-height: 100%; }

body {
  min-height: 100vh;
  background-color: #ffffff;
}

/* =========================
   Logo
========================= */
.lvwa_berlin_logo {
  padding: 0 !important;
  margin: 0 !important;
  width: 120px;
  height: 50px;
  background-color: #666; /* falls nur Debug/Platzhalter -> ggf. entfernen */
}

.lvwa_berlin_logo_img {
  width: 120px;
  height: 50px;
  /* border: 0px dotted #ff0000 !important; */ /* Debug */
}

/* =========================
   Navbar (global, alle Browser)
========================= */
/* komplett transparent, kein Balken */
.navbar,
.navbar-brand,
.navbar-item {
  background-color: transparent !important;
}

/* keine Bulma-Standardhöhe + kein Padding */
.navbar {
  padding: 0 !important;
  min-height: 0 !important;
}

.navbar-brand {
  min-height: 0 !important;
}

/* Debug: Rahmen anzeigen (bei Bedarf aktivieren) */
/*
.navbar { border: 1px dashed blue; }
.navbar-item { border: 1px dotted red; }
*/

/* =========================
   Mobile Layout: Logo links, KI-Hinweis rechts
========================= */
@media (max-width: 1023px) {
  .navbar-brand {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    flex-wrap: nowrap;
    width: 100%;
  }

  /* Kinder nicht auf 100% Breite ziehen */
  .navbar-brand > .navbar-item {
    flex: 0 0 auto;
  }

  /* KI-Hinweis (mobile Version) nie umbrechen */
  .navbar-brand > .is-hidden-desktop {
    white-space: nowrap;
  }
}

/* =========================
   Textarea (unverändert)
========================= */
.textarea {
  font-size: 1.4rem;
  height: 100px;
  color: #333;
  border: 3px solid #eee;
  resize: none;
  background-color: #fff;
  opacity: 1 !important;
}

.textarea::placeholder {
  font-size: 1.4rem;
  font-weight: 700;
  color: #666;
  opacity: 1 !important;
}



/* ========== CHAT FIX ========== */
/* Main Container*/
.message_main_container {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    max-width: 800px !important;
    margin: 0 auto !important;
    opacity: 1 !important;
    filter: none !important;
    backdrop-filter: none !important;
}


.messages_container[_ngcontent-ng-c234277468] .message_container[_ngcontent-ng-c234277468] .message_assistant[_ngcontent-ng-c234277468] {
    background: #fff;
    opacity: 1 !important;
    border-radius: 2px 20px 20px;
    color: #000;
}
/* Killt Transparenz auf dem Container (das ist der entscheidende Fix) */
.messages_container .message_container,
.messages_container .message_container * {
  opacity: 1 !important;
}


.messages_container .appear-animation,
.messages_container .appear-animation * {
  opacity: 1 !important;
}
.message_container.message_container_assistant,
.message_container.message_container_user {
  opacity: 1 !important;
}


/* Wrapper für Bot-Nachrichten mit Quellen-Button */
.assistant_message_wrapper {
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
    margin-bottom: 15px !important;
    width: 100% !important;
    position: relative !important;
    opacity: 1 !important;
    margin-top: 12px !important;
}

/* Container für die Nachricht */
.message_container_assistant {
    flex: 1 !important;
    min-width: 0 !important;
    display: block !important;
    opacity: 1 !important;
}
.message_container_user {
    display: flex !important;
    justify-content: flex-end !important;
    margin-bottom: 12px !important;
    opacity: 1 !important;
}
.message.message_assistant.appear-animation,
.message.message_user.appear-animation {
    opacity: 1 !important;
}
/* Bot-Nachrichten Box*/
.message.message_assistant {
    /*background-color: rgb(240, 240, 240) !important;*/ 
    background-color: #f0f0f0 !important;
    padding: 8px 12px !important;
    border-radius: 12px !important;
    color: #222 !important;
    font-size: 1.05rem !important;
    line-height: 1.35 !important;
    word-wrap: break-word !important;
    white-space: pre-wrap !important;
    display: block !important;
    width: 100% !important;
    min-height: auto !important;
    height: auto !important;
    box-sizing: border-box !important;
    text-shadow: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
}

/* Container niemals transparent */
.messages_container,
.message_container,
.message_container_assistant,
.message_container_user,
.appear-animation {
    opacity: 1 !important;
    background-color: #f0f0f0 !important;
}

.message.message_assistant span {
    display: block !important;
    width: 100% !important;
    opacity: 1 !important;
    background-color: #f0f0f0 !important;
}

/* User-Nachricht*/
.message.message_user {
    /*background-color: rgb(240, 240, 240) !important;*/
    background-color: #f0f0f0 !important;
    padding: 12px 16px !important;
    border-radius: 12px !important;
    color: #222 !important;
    font-size: 1.3rem !important;
    line-height: 1.6 !important;
    word-wrap: break-word !important;
    overflow-wrap: anywhere !important;    
    white-space: pre-wrap !important;
    display: inline-block !important;
    max-width: 52% !important; 
    box-sizing: border-box !important;  
    color: #fff !important;
    text-shadow: none !important;
    box-shadow: none !important;
    opacity: 1 !important;
}

/* Textgröße Bot - separat weil keine Änderungen im vorherigen Block durchgeführt wurden 
.message.message_assistant,
.message.message_assistant * {
  font-size: 1.15rem !important;
  color: #000000 !important;
  opacity: 1 !important;
}*/

/* Textgröße User - separat weil keine Änderungen im vorherigen Block durchgeführt wurden 
.message.message_user * {
  font-size: 1.15rem !important;
  color: #002856 !important;
  opacity: 1 !important;
}*/


/* Quellen-Button links neben der Nachricht */
button.sources_button_adjacent {
    flex-shrink: 0 !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    min-height: 32px !important;
    border-radius: 50% !important;
    background-color: #002856 !important;
    color: white !important;
    border: 2px solid #002856 !important;
    cursor: pointer !important;
    font-weight: bold !important;
    font-size: 14px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-top: 0px !important;
    padding: 0 !important;
    line-height: 1 !important;
}

button.sources_button_adjacent:hover {
    background-color: #0056b3 !important;
    border-color: #0056b3 !important;
}

/* Quellen-List */
.sources_list_adjacent {
    position: absolute !important;
    left: 0 !important;
    top: 100% !important;
    margin-top: 8px !important;
    background-color: white !important;
    border: 2px solid #ddd !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2) !important;
    z-index: 100 !important;
    min-width: 300px !important;
    max-width: 500px !important;
    font-size: 0.95rem !important;
}

.sources_list_adjacent strong {
    display: block !important;
    margin-bottom: 8px !important;
    color: #333 !important;
    font-size: 1rem !important;
}

.sources_list_adjacent ul {
    margin: 0 !important;
    padding-left: 20px !important;
    list-style-type: disc !important;
}

.sources_list_adjacent li {
    margin-bottom: 6px !important;
    line-height: 1.5 !important;
    color: #555 !important;
}

/* Messages Container*/
.messages_container {
    background-color: #f0f0f0 !important;
    position: relative !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    max-height: 450px !important; 
    padding-right: 10px !important;
    margin-left: 0 !important; 
    padding-left: 10px !important;
    margin-top: 20px !important;
    opacity: 1 !important;
   -webkit-mask-image: none !important;
    mask-image: none !important;
    background: transparent !important;
    padding-top: clamp(140px, 18vh, 240px) !important;
}

/* Scrollbar Styling*/
.messages_container::-webkit-scrollbar {
    width: 8px !important;
}

.messages_container::-webkit-scrollbar-track {
    background: #f1f1f1 !important;
    border-radius: 10px !important;
}

.messages_container::-webkit-scrollbar-thumb {
    background: #888 !important;
    border-radius: 10px !important;
}

.messages_container::-webkit-scrollbar-thumb:hover {
    background: #555 !important;
}

/* Textfarbe Eingabefeld */
.input {
  font-size: 24px !important;
  color: #222;
}


.button {
    font-weight: 700;
    color: #002856;
/*     background-color: #fff;
    border: 3px solid #eee; */
}


/* .section {
    border: 3px dotted green;
}

.chatbot_content {
    border: 3px dotted blue;
}
 */


.qr-code {
position: absolute;
top: 10%;
left: 18%;
display: none !important;
z-index: 100;
height: 128px;
width: 108px;
border: 1px dashed red !important;
}

.qr-code2 {
position: absolute;
top: 30%;
left: 85%;
display: none !important;
z-index: 100;
height: 128px;
width: 108px;
border: 1px dashed blue !important;
}

.qr-code3 {
position: absolute;
top: 50%;
left: 4% !important;
display: none !important;
z-index: 100;
height: 128px;
width: 108px;
border: 1px dashed green !important;
object-fit: contain;
}

/* ################################ BULMA ################################### */
/* Fixes for message Containers form and positioning*/
.message_container_assistant .message.message_assistant,
.message_container_user .message.message_user {
  border-radius: 12px !important;
  overflow: hidden !important;
}
.message_container_assistant,
.message_container_user {
  border-radius: 12px !important;
  overflow: hidden !important;
}



/* ===== STOP SHRINK ===== */
.messages_container .message_container {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  flex: 0 0 auto !important;
}

/* User-Row rechts */
.messages_container .message_container.message_container_user {
  display: flex !important;
  justify-content: flex-end !important;
}

/* Assistant-Row links */
.messages_container .message_container.message_container_assistant {
  display: flex !important;
  justify-content: flex-start !important;
}


.messages_container .message_container_user .message.message_user {
  display: inline-block !important;      
  width: auto !important;
  max-width: 65% !important;
  flex: 0 0 auto !important;
  text-align: right !important;
}

/* Assistant-Bubble */
.messages_container .message_container_assistant .message.message_assistant {
  display: inline-block !important;      
  width: auto !important;
  max-width: 75% !important;
  flex: 0 0 auto !important;
}
/* Desktop: Avatar kleiner, Schultern sichtbar */
  @media (min-width: 901px) {
    .video-container {
      position: fixed !important;
      inset: 0 !important;
      width: 100vw !important;
      height: 100vh !important;
      overflow: hidden !important;
    }
    .video-container video,
    .video-layer,
    .video-idle,
    .video-active {
      position: absolute !important;
      left: 50% !important;
      bottom: 0 !important;
      width: 100% !important;
      height: 100% !important;
      transform: translateX(-50%) scale(0.7) !important;
      transform-origin: bottom center !important;
      object-fit: contain !important;
      object-position: center bottom !important;
    }
  }
/* ===== Desktop Avatar Fix (Chatbots) ===== */
  @media (min-width: 901px) {
    .video-container {
      position: fixed !important;
      inset: 0 !important;
      width: 100vw !important;
      height: 100vh !important;
      overflow: hidden !important;
    }

    .video-container video,
    .video-layer,
    .video-idle,
    .video-active {
      position: absolute !important;
      left: 50% !important;
      bottom: 0 !important;
      width: 100% !important;
      height: 100% !important;
      transform: translateX(-50%) scale(0.65) !important;
      transform-origin: bottom center !important;
      object-fit: contain !important;
      object-position: center bottom !important;
    }
  }
