/* ============================================================
   WPLINE Form AI — wpline-chat.css  v2.0
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ── Wrapper du formulaire standalone ── */
#wpline-form-wrapper {
  width: 100% !important;
  box-sizing: border-box !important;
  font-family: 'Inter', sans-serif !important;
}

/* ── Ligne de champs ── */
.wpline-fields-row {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 10px !important;
  margin-bottom: 16px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* ── Wrapper de chaque champ (pour le message d'erreur) ── */
.wpline-field-wrap {
  flex: 1 1 160px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
  min-width: 0 !important;
}

/* ── Champ individuel ── */
.wpline-field-input {
  width: 100% !important;
  border: 1.5px solid #d1d5db !important;
  border-radius: 8px !important;
  padding: 10px 14px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 14px !important;
  color: #111827 !important;
  background: #ffffff !important;
  outline: none !important;
  transition: border-color .2s, box-shadow .2s !important;
  box-sizing: border-box !important;
}

.wpline-field-input::placeholder {
  color: #9ca3af !important;
}

.wpline-field-input:focus {
  border-color: #6b7280 !important;
  box-shadow: 0 0 0 3px rgba(107,114,128,.10) !important;
}

/* ── Champ valide : bordure verte ── */
.wpline-field-input.wpline-field-filled {
  border-color: #22c55e !important;
  box-shadow: 0 0 0 3px rgba(34,197,94,.10) !important;
}

/* ── Champ invalide : bordure rouge ── */
.wpline-field-input.wpline-field-error {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 3px rgba(239,68,68,.10) !important;
}

/* ── Champ verrouillé / grisé ── */
.wpline-field-input.wpline-field-locked,
.wpline-field-input:disabled {
  background: #f3f4f6 !important;
  border-color: #e5e7eb !important;
  color: #9ca3af !important;
  cursor: not-allowed !important;
  box-shadow: none !important;
  opacity: .6 !important;
}

/* ── Champ pré-rempli (utilisateur connecté) : non grisé, éditable, déjà validé ── */
.wpline-field-input.wpline-field-prefilled:not(:disabled) {
  background: #ffffff !important;
  color: #111827 !important;
  opacity: 1 !important;
  cursor: text !important;
}

/* ── Message d'erreur sous le champ ── */
.wpline-field-hint {
  font-family: 'Inter', sans-serif !important;
  font-size: 11.5px !important;
  color: #ef4444 !important;
  padding: 0 2px !important;
  min-height: 15px !important;
  line-height: 1.3 !important;
}

/* ── Wrapper global du chat ── */
#wplai-chat-zone {
  display: flex !important;
  flex-direction: column !important;
  border: 1.5px solid #e5e7eb !important;
  border-radius: 14px !important;
  background: #ffffff !important;
  overflow: hidden !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04) !important;
  font-family: 'Inter', sans-serif !important;
  width: 80% !important;
  box-sizing: border-box !important;
  margin-bottom: 12px !important;
  justify-self: center !important;
}

/* ── Zone messages ── */
#wplai-chat-zone .wplai-msgs {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  overflow-y: auto !important;
  padding: 16px 14px 10px !important;
  min-height: 140px !important;
  max-height: 240px !important;
  scroll-behavior: smooth !important;
  background: #ffffff !important;
  box-sizing: border-box !important;
}

#wplai-chat-zone .wplai-msgs::-webkit-scrollbar { width: 3px; }
#wplai-chat-zone .wplai-msgs::-webkit-scrollbar-thumb {
  background: #d1d5db !important;
  border-radius: 3px !important;
}

#wplai-chat-zone .wplai-msg {
  display: flex !important;
  flex-direction: column !important;
  max-width: 78% !important;
  gap: 3px !important;
}

#wplai-chat-zone .wplai-msg-bot  { align-self: flex-start !important; align-items: flex-start !important; }
#wplai-chat-zone .wplai-msg-user { align-self: flex-end !important;   align-items: flex-end !important;   }

#wplai-chat-zone .wplai-bubble {
  padding: 9px 13px !important;
  border-radius: 12px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  line-height: 1.6 !important;
  word-break: break-word !important;
}

#wplai-chat-zone .wplai-msg-bot .wplai-bubble {
  background: #f1f3f9 !important;
  color: #111827 !important;
  border-bottom-left-radius: 3px !important;
}

#wplai-chat-zone .wplai-msg-user .wplai-bubble {
  background: #ff9b31 !important;
  color: #ffffff !important;
  border-bottom-right-radius: 3px !important;
}

#wplai-chat-zone .wplai-time {
  font-size: 10px !important;
  color: #9ca3af !important;
  padding: 0 3px !important;
  font-family: 'Inter', sans-serif !important;
}

/* ── Typing ── */
#wplai-chat-zone .wplai-typing .wplai-bubble {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  padding: 11px 14px !important;
  min-width: 52px !important;
}

#wplai-chat-zone .wplai-dot-t {
  display: inline-block !important;
  width: 6px !important;
  height: 6px !important;
  background: #9ca3af !important;
  border-radius: 50% !important;
  animation: wplai-bounce .9s infinite !important;
}

#wplai-chat-zone .wplai-dot-t:nth-child(2) { animation-delay: .15s !important; }
#wplai-chat-zone .wplai-dot-t:nth-child(3) { animation-delay: .30s !important; }

@keyframes wplai-bounce {
  0%,60%,100% { transform: translateY(0); }
  30%          { transform: translateY(-4px); }
}

/* ── Boutons de réponse rapide ── */
#wplai-quick-replies {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  padding: 8px 14px 10px !important;
  background: #f9fafb !important;
  border-top: 1px solid #e5e7eb !important;
  min-height: 0 !important;
}

#wplai-quick-replies:empty {
  display: none !important;
}

.wplai-quick-btn {
  background: #ffffff !important;
  border: 1.5px solid #d1d5db !important;
  color: #374151 !important;
  border-radius: 20px !important;
  padding: 6px 14px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background .15s, color .15s, border-color .15s, transform .12s !important;
  white-space: nowrap !important;
  line-height: 1.3 !important;
}

.wplai-quick-btn:hover {
  background: #f3f4f6 !important;
  border-color: #9ca3af !important;
  transform: scale(1.04) !important;
}

.wplai-quick-btn:active {
  transform: scale(.96) !important;
}

/* ── Barre de saisie ── */
#wplai-chat-zone .wplai-input-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: flex-end !important;
  gap: 8px !important;
  padding: 10px 12px !important;
  border-top: 1px solid #e5e7eb !important;
  background: #f9fafb !important;
  flex-shrink: 0 !important;
  box-sizing: border-box !important;
}

#wplai-user-input {
  flex: 1 1 auto !important;
  border: 1.5px solid #e5e7eb !important;
  border-radius: 10px !important;
  padding: 9px 12px !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  color: #111827 !important;
  resize: none !important;
  outline: none !important;
  max-height: 88px !important;
  min-height: 38px !important;
  line-height: 1.5 !important;
  background: #ffffff !important;
  transition: border-color .15s, box-shadow .15s !important;
  box-sizing: border-box !important;
}

#wplai-user-input:focus {
  border-color: #9ca3af !important;
  box-shadow: 0 0 0 3px rgba(156,163,175,.12) !important;
}

#wplai-user-input::placeholder { color: #c4c9d8 !important; }

#wplai-send-btn {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  border-radius: 10px !important;
  background: #ff9b31 !important;
  border: none !important;
  cursor: pointer !important;
  color: #ffffff !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  box-shadow: 0 2px 8px rgba(255,155,49,.35) !important;
  transition: background .15s, transform .12s !important;
  padding: 0 !important;
}

#wplai-send-btn:hover  { background: #e8870f !important; transform: scale(1.06) !important; }
#wplai-send-btn:active { transform: scale(.93) !important; }
#wplai-send-btn:disabled {
  background: #e0c9ad !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
  transform: none !important;
}

/* ── Formulaire inline dans le chat ── */
#wplai-chat-zone .wplai-bubble-form {
  background: #fff8f2 !important;
  border: 1.5px solid #ffd49e !important;
  padding: 12px 14px !important;
  max-width: 92% !important;
}

#wplai-chat-zone .wplai-if-title {
  font-size: 12.5px !important;
  font-weight: 700 !important;
  color: #7c3d00 !important;
  margin: 0 0 10px !important;
  font-family: 'Inter', sans-serif !important;
}

#wplai-chat-zone .wplai-if-row {
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
  margin-bottom: 8px !important;
}

#wplai-chat-zone .wplai-if-label {
  font-size: 11.5px !important;
  font-weight: 600 !important;
  color: #4b3220 !important;
  font-family: 'Inter', sans-serif !important;
}

#wplai-chat-zone .wplai-opt {
  font-weight: 400 !important;
  color: #aaa !important;
  font-size: 10.5px !important;
}

#wplai-chat-zone .wplai-if-input {
  border: 1.5px solid #f0d4b0 !important;
  border-radius: 8px !important;
  padding: 7px 10px !important;
  font-size: 12.5px !important;
  font-family: 'Inter', sans-serif !important;
  color: #111827 !important;
  outline: none !important;
  background: #ffffff !important;
  transition: border-color .15s, box-shadow .15s !important;
  box-sizing: border-box !important;
  width: 100% !important;
}

#wplai-chat-zone .wplai-if-input:focus {
  border-color: #ff9b31 !important;
  box-shadow: 0 0 0 3px rgba(255,155,49,.12) !important;
}

#wplai-chat-zone .wplai-if-error {
  border-color: #e53e3e !important;
  box-shadow: 0 0 0 3px rgba(229,62,62,.10) !important;
}

#wplai-chat-zone .wplai-if-input:disabled {
  background: #f5f5f5 !important;
  color: #999 !important;
}

#wplai-chat-zone .wplai-if-submit {
  width: 100% !important;
  background: #ff9b31 !important;
  color: #ffffff !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 9px 0 !important;
  font-family: 'Inter', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: background .15s, transform .1s !important;
  margin-top: 4px !important;
}

#wplai-chat-zone .wplai-if-submit:hover  { background: #e8870f !important; }
#wplai-chat-zone .wplai-if-submit:active { transform: scale(.98) !important; }
#wplai-chat-zone .wplai-if-submit:disabled {
  background: #e0c9ad !important;
  cursor: not-allowed !important;
}

/* ── Cache le widget flottant ── */
div#wpline-chat-widget {
  display: none !important;
}

/* ============================================================
   Upload de fichiers dans le chat
   ============================================================ */

/* Bouton upload (trombone) à gauche de la zone de saisie */
#wplai-upload-btn {
  width: 38px !important;
  height: 38px !important;
  min-width: 38px !important;
  border-radius: 10px !important;
  background: #ffffff !important;
  border: 1.5px solid #e5e7eb !important;
  cursor: pointer !important;
  color: #6b7280 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  transition: background .15s, border-color .15s, color .15s, transform .12s !important;
  padding: 0 !important;
}

#wplai-upload-btn:hover {
  background: #f3f4f6 !important;
  border-color: #ff9b31 !important;
  color: #ff9b31 !important;
  transform: scale(1.06) !important;
}

#wplai-upload-btn:active { transform: scale(.93) !important; }

#wplai-upload-btn:disabled {
  opacity: .5 !important;
  cursor: not-allowed !important;
  transform: none !important;
}

/* Zone preview au-dessus de la saisie */
#wplai-attachments-preview {
  display: none;
  flex-wrap: wrap !important;
  gap: 8px !important;
  padding: 10px 12px !important;
  border-top: 1px solid #e5e7eb !important;
  background: #fff8f2 !important;
  max-height: 140px !important;
  overflow-y: auto !important;
}

#wplai-attachments-preview.has-files {
  display: flex !important;
}

.wplai-attachment-item {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: #ffffff !important;
  border: 1.5px solid #ffd49e !important;
  border-radius: 8px !important;
  padding: 5px 8px 5px 5px !important;
  font-size: 12px !important;
  font-family: 'Inter', sans-serif !important;
  color: #4b3220 !important;
  max-width: 100% !important;
  animation: wplai-fade-in .2s ease !important;
}

@keyframes wplai-fade-in {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0);    }
}

.wplai-attachment-item.uploading {
  opacity: .7 !important;
  border-style: dashed !important;
}

.wplai-attachment-item.error {
  border-color: #ef4444 !important;
  color: #b91c1c !important;
  background: #fef2f2 !important;
}

.wplai-attachment-thumb {
  width: 32px !important;
  height: 32px !important;
  border-radius: 5px !important;
  object-fit: cover !important;
  background: #f3f4f6 !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: #6b7280 !important;
}

.wplai-attachment-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  border-radius: 5px !important;
}

.wplai-attachment-name {
  font-weight: 500 !important;
  max-width: 140px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.wplai-attachment-size {
  color: #9ca3af !important;
  font-size: 10.5px !important;
  flex-shrink: 0 !important;
}

.wplai-attachment-remove {
  background: transparent !important;
  border: none !important;
  color: #9ca3af !important;
  cursor: pointer !important;
  padding: 2px 4px !important;
  border-radius: 4px !important;
  font-size: 14px !important;
  line-height: 1 !important;
  transition: background .15s, color .15s !important;
}

.wplai-attachment-remove:hover {
  background: #fee2e2 !important;
  color: #dc2626 !important;
}

.wplai-attachment-spinner {
  width: 14px !important;
  height: 14px !important;
  border: 2px solid #ffd49e !important;
  border-top-color: #ff9b31 !important;
  border-radius: 50% !important;
  animation: wplai-spin .7s linear infinite !important;
  flex-shrink: 0 !important;
}

@keyframes wplai-spin {
  to { transform: rotate(360deg); }
}

/* Drag & drop highlight */
#wplai-chat-zone.wplai-drag-over {
  box-shadow: 0 0 0 3px #ff9b31, 0 4px 20px rgba(255,155,49,.3) !important;
}

#wplai-chat-zone.wplai-drag-over .wplai-msgs::before {
  content: "📎 Déposez votre fichier ici";
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  position: absolute !important;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(255,248,242,.95) !important;
  color: #ff9b31 !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  z-index: 10 !important;
  pointer-events: none !important;
}

#wplai-chat-zone { position: relative !important; }

/* Attachments affichés dans les bulles utilisateur */
.wplai-bubble-attachments {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  margin-top: 6px !important;
}

.wplai-bubble-attachment {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  background: rgba(255,255,255,.2) !important;
  border-radius: 8px !important;
  padding: 6px 8px !important;
  color: #ffffff !important;
  text-decoration: none !important;
  font-size: 12px !important;
  transition: background .15s !important;
}

.wplai-bubble-attachment:hover {
  background: rgba(255,255,255,.35) !important;
}

.wplai-bubble-attachment img {
  max-width: 100% !important;
  max-height: 180px !important;
  border-radius: 6px !important;
  display: block !important;
}


/* ============================================================
   Responsive mobile
   ============================================================ */
@media (max-width: 600px) {

  /* Le chat prend toute la largeur dispo */
  #wplai-chat-zone {
    width: 100% !important;
    border-radius: 12px !important;
  }

  /* Bulles plus larges → le texte respire */
  #wplai-chat-zone .wplai-msg {
    max-width: 90% !important;
  }

  #wplai-chat-zone .wplai-bubble {
    font-size: 14px !important;
    padding: 10px 13px !important;
  }

  /* Zone messages */
  #wplai-chat-zone .wplai-msgs {
    padding: 14px 12px 8px !important;
    min-height: 160px !important;
    max-height: 50vh !important;
  }

  /* Barre de saisie */
  #wplai-chat-zone .wplai-input-row {
    gap: 6px !important;
    padding: 8px 10px !important;
  }

  /* Textarea : hauteur suffisante + 16px pour bloquer le zoom iOS */
  #wplai-user-input {
    font-size: 12px !important;
    min-height: 44px !important;
    line-height: 1.35 !important;
  }

  /* Placeholder sur 1 ligne, coupé proprement avec "..." */
  #wplai-user-input::placeholder {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }

  /* Boutons : taille tactile confortable */
  #wplai-send-btn,
  #wplai-upload-btn {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
  }

  /* Champs du formulaire empilés en pleine largeur */
  .wpline-field-wrap {
    flex: 1 1 100% !important;
  }

  /* Réponses rapides */
  #wplai-quick-replies {
    padding: 8px 10px !important;
  }
}