/* Floating Contact + Mini Chatbot (premium) */
.floating-contact{
  position:fixed;
  right:18px;
  bottom:18px;
  display:flex;
  flex-direction:column;
  align-items:flex-end; /* right-aligned stack */
  gap:10px;
  z-index:999999;
}

/* Buttons */
.floating-contact .float-btn{
  width:52px;
  height:52px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  cursor:pointer;
  user-select:none;
  text-decoration:none;
  border:2px solid rgba(255,255,255,.14);
  box-shadow:0 12px 28px rgba(0,0,0,.25);
  backdrop-filter: blur(6px);
}

.floating-contact .float-btn svg{
  width:22px;
  height:22px;
  display:block;
  fill:#fff;
}

/* Brand colors */
.float-btn.whatsapp{background:#25D366;}
.float-btn.instagram{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF,#515BD4);}
.float-btn.facebook{background:#1877F2;}
.float-btn.chat{background:#c5a47e;}

/* Chat pill */
.floating-contact .float-btn.chat{
  width:auto;
  height:52px;
  padding:0 14px;
  gap:10px;
}
.floating-contact .float-btn.chat span{
  color:#fff;
  font-weight:800;
  font-size:13px;
  letter-spacing:.2px;
  white-space:nowrap;
}

/* Badge */
.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:240px;
  line-height:1.2;
  display:none;
}

/* Mini chat */
.mini-chat{
  position:fixed;
  right:18px;
  bottom:86px;
  width:min(380px, 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;
}
.mini-chat .chat-body p{margin:0;}

/* 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));}
}

/* Slightly roomier on desktop */
@media (min-width: 768px){
  .floating-contact{right:22px; bottom:22px;}
  .mini-chat{right:22px;}
}
