/* Prevent theme CSS from messing with our layout */
.ts-chat, .ts-chat * {
  box-sizing: border-box;
}

.ts-chat p,
.ts-chat h1, .ts-chat h2, .ts-chat h3,
.ts-chat ul, .ts-chat ol {
  margin: 0;
  padding: 0;
}

.ts-chat button {
  font: inherit;
}


.ts-chat {
  max-width: 820px;
  margin: 0 auto;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  overflow: hidden;

  display: flex;
  flex-direction: column;
  min-height: 520px;   /* add */
}

.ts-chat__title { font-size: 18px; font-weight: 700; }
.ts-chat__subtitle { opacity: .7; margin-top: 4px; }

.ts-chat__messages {
  padding: 16px 18px;
  min-height: 200px;
  flex: 1;                 /* ← THIS IS KEY */
  background: rgba(0,0,0,.02);
  overflow-y: auto;        /* ← so messages scroll */
}

.ts-msg {
  width: 100%;
  margin: 10px 0;
  display: flex;
}

.ts-msg--user {
  justify-content: flex-end;
}

.ts-msg__bubble {
  max-width: 80%;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;
  white-space: pre-wrap;
}
.ts-msg--user .ts-msg__bubble {
  background: rgba(0,0,0,.06);
}

.ts-cards {
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 12px;
}

.ts-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,.10);
  border-radius: 14px;
  overflow: hidden;
}
.ts-card img {
  width: 100%;
  height: 160px;
  object-fit: cover;
  display: block;
}
.ts-card__body { padding: 10px 12px; }
.ts-card__name { font-weight: 700; }
.ts-card__price { opacity: .75; margin-top: 4px; }
.ts-card__actions { margin-top: 10px; display: flex; gap: 8px; flex-wrap: wrap; }
.ts-btn {
  display: inline-block;
  padding: 8px 10px;
  border-radius: 10px;
  border: 1px solid rgba(0,0,0,.14);
  text-decoration: none;
  font-size: 14px;
}

.ts-chat__composer {
  display: flex;
  gap: 10px;
  padding: 12px;
  border-top: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

.ts-chat__hint {
  padding: 8px 14px 12px;
  font-size: 13px;
  opacity: .7;
  background: #fff;
}

.ts-chat__input {
  flex: 1;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.18);
}

.ts-chat__send {
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.18);
  background: #fff;
  cursor: pointer;
}


.ts-chat__header {
  padding: 14px 18px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  background: #fff;
}

.ts-chat__title {
  font-size: 17px;
  font-weight: 700;
}

.ts-chat__subtitle {
  opacity: .75;
  margin-top: 6px;
  font-size: 14px;
  line-height: 1.4;
}
