
.legalgpt-widget{
  border:1px solid #e5e7eb;
  border-radius:14px;
  overflow:hidden;
  max-width:720px;
  margin:18px 0;
  background:#fff;
  box-shadow:0 2px 14px rgba(0,0,0,.06);
}
.legalgpt-header{
  padding:14px 16px;
  background:#f7f7f8;
  border-bottom:1px solid #e5e7eb;
}
.legalgpt-title{ font-weight:700; font-size:16px; }
.legalgpt-subtitle{ font-size:12px; color:#6b7280; margin-top:2px; }

.legalgpt-body{ padding:14px 16px; }
.legalgpt-messages{
  height:320px;
  overflow:auto;
  padding:8px;
  background:#fafafa;
  border:1px solid #eee;
  border-radius:12px;
}
.legalgpt-msg{ display:flex; margin:8px 0; }
.legalgpt-user{ justify-content:flex-end; }
.legalgpt-bot{ justify-content:flex-start; }
.legalgpt-bubble{
  max-width:86%;
  padding:10px 12px;
  border-radius:12px;
  line-height:1.35;
  white-space:pre-wrap;
  background:#111827;
  color:#fff;
}
.legalgpt-user .legalgpt-bubble{ background:#2563eb; }
.legalgpt-input{
  display:flex;
  gap:10px;
  margin-top:10px;
}
.legalgpt-textarea{
  flex:1;
  resize:vertical;
  min-height:44px;
  border-radius:12px;
  border:1px solid #e5e7eb;
  padding:10px;
}
.legalgpt-send{
  border-radius:12px;
  border:1px solid #e5e7eb;
  padding:10px 14px;
  cursor:pointer;
  background:#fff;
}
.legalgpt-send:disabled{ opacity:.6; cursor:not-allowed; }
.legalgpt-hint{ margin-top:8px; font-size:12px; color:#6b7280; }
