/* Floating Contact + Mini Chatbot (mobile-first) */
.floating-contact{
  position:fixed;
  right:18px;
  bottom:18px;
  display:flex;
  flex-direction:column;
  gap:10px;
  z-index:999999;
}
.floating-contact .float-btn{
  width:52px;
  height:52px;
  border-radius:14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  color:#fff;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
  user-select:none;
}
.float-btn.whatsapp{background:#25D366;}
.float-btn.instagram{background:#E1306C;}
.float-btn.facebook{background:#1877F2;}
.float-btn.chat{background:#c5a47e;}
.float-badge{
  position:absolute;
  right:64px;
  bottom:6px;
  background:rgba(0,0,0,.72);
  color:#fff;
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  max-width:220px;
  line-height:1.2;
  display:none;
}

/* Mini chat */
.mini-chat{
  position:fixed;
  right:18px;
  bottom:86px;
  width:min(340px, calc(100vw - 36px));
  background:#fff;
  border-radius:16px;
  display:none;
  box-shadow:0 18px 55px rgba(0,0,0,.25);
  overflow:hidden;
  z-index:999999;
}
.mini-chat .chat-header{
  background:#c5a47e;
  color:#fff;
  padding:12px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-weight:700;
}
.mini-chat .chat-header button{
  border:none;
  background:rgba(255,255,255,.18);
  color:#fff;
  width:34px;
  height:34px;
  border-radius:10px;
  cursor:pointer;
}
.mini-chat .chat-body{padding:14px;}
.mini-chat .q{font-weight:700;margin:0 0 10px 0;color:#111;}
.mini-chat .hint{margin:8px 0 0 0;font-size:12px;color:#666;}
.mini-chat input, .mini-chat select{
  width:100%;
  padding:12px 12px;
  border:1px solid #e5e7eb;
  border-radius:12px;
  outline:none;
  font-size:14px;
}
.mini-chat .actions{display:flex;gap:10px;margin-top:12px;}
.mini-chat .btn{
  flex:1;
  padding:12px 12px;
  border-radius:12px;
  border:none;
  cursor:pointer;
  font-weight:700;
}
.mini-chat .btn.primary{background:#c5a47e;color:#fff;}
.mini-chat .btn.ghost{background:#f3f4f6;color:#111;}
.mini-chat .progress{
  height:6px;
  background:#f3f4f6;
  border-radius:999px;
  overflow:hidden;
  margin:10px 0 0 0;
}
.mini-chat .progress > span{
  display:block;
  height:100%;
  width:0%;
  background:#c5a47e;
  transition:width .25s ease;
}

/* Safe area */
@supports(padding:max(0px)){
  .floating-contact{bottom:calc(18px + env(safe-area-inset-bottom));}
  .mini-chat{bottom:calc(86px + env(safe-area-inset-bottom));}
}
/* Bigger chat button + label */
.floating-contact .float-btn.chat{
  width:auto;
  min-width:170px;
  padding:0 14px;
  border-radius:16px;
  font-size:14px;
  gap:10px;
  justify-content:flex-start;
}
.floating-contact .float-btn.chat::before{
  content:"💬";
  font-size:18px;
}
.floating-contact .float-btn.chat::after{
  content:"Kostenlose Beratung";
  font-weight:800;
  letter-spacing:.2px;
}

/* Make it a bit higher on desktop */
@media (min-width: 768px){
  .floating-contact{right:22px; bottom:22px;}
}
/* Chat window larger like real chat */
.mini-chat{
  width:min(380px, calc(100vw - 36px));
}
.mini-chat .chat-body p{
  margin:0;
}
