/* =====================================================
   VS AI Chat — scoped inside #vs-ai-chat-widget
   ===================================================== */

#vs-ai-chat-widget {
  --vsai-primary:     #1fe07a;
  --vsai-primary-dk:  #17b862;
  --vsai-bg:          #ffffff;
  --vsai-bg2:         #f9f9f9;
  --vsai-bg3:         #f5f5f5;
  --vsai-bg4:         #eeeeee;
  --vsai-border:      rgba(0,0,0,0.08);
  --vsai-text:        #111111;
  --vsai-text-dim:    rgba(0,0,0,0.55);
  --vsai-text-muted:  rgba(0,0,0,0.38);
  --vsai-br:          16px;
  --vsai-br-sm:       10px;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  color: var(--vsai-text);
  box-sizing: border-box;
}

#vs-ai-chat-widget *, #vs-ai-chat-widget *::before, #vs-ai-chat-widget *::after {
  box-sizing: inherit;
}

/* ---- FAB ---- */
#vs-ai-chat-widget .ai-fab {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 100001;
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 8px;
  background: #111;
  border: none;
  border-radius: 50px;
  padding: 13px 18px 13px 14px;
  cursor: pointer;
  transition: opacity 0.25s, transform 0.2s ease;
  box-shadow: 0 4px 24px rgba(0,0,0,0.28);
}

#vs-ai-chat-widget .ai-fab:hover {
  transform: scale(1.04);
}

#vs-ai-chat-widget .ai-fab:active {
  transform: scale(0.96);
}

#vs-ai-chat-widget .ai-fab.is-hidden {
  opacity: 0;
  pointer-events: none;
  transform: scale(0.8);
}

#vs-ai-chat-widget .ai-fab__icon {
  width: 22px;
  height: 22px;
  color: var(--vsai-primary);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

#vs-ai-chat-widget .ai-fab__icon svg {
  width: 22px;
  height: 22px;
}

#vs-ai-chat-widget .ai-fab__label {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  white-space: nowrap;
}

/* ---- Backdrop ---- */
#vs-ai-chat-widget .ai-backdrop {
  position: fixed;
  inset: 0;
  z-index: 100000;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.35s ease;
}

#vs-ai-chat-widget .ai-backdrop.is-visible {
  opacity: 1;
  pointer-events: all;
}

/* ---- Sheet (desktop popup widget) ---- */
#vs-ai-chat-widget .ai-sheet {
  position: fixed;
  bottom: 92px;
  right: 24px;
  width: 390px;
  height: min(640px, calc(100svh - 112px));
  z-index: 100001;
  background: var(--vsai-bg);
  border-radius: 20px;
  box-shadow: 0 8px 48px rgba(0,0,0,0.18), 0 2px 12px rgba(0,0,0,0.1);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: scale(0.94) translateY(16px);
  transform-origin: bottom right;
  opacity: 0;
  pointer-events: none;
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1), opacity 0.25s ease;
  will-change: transform, opacity;
}

#vs-ai-chat-widget .ai-sheet.is-open {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: all;
}

/* Mobile: revert to full-width bottom sheet */
@media (max-width: 480px) {
  #vs-ai-chat-widget .ai-fab {
    right: 16px;
    bottom: 16px;
  }
  #vs-ai-chat-widget .ai-sheet {
    bottom: 0;
    right: 0;
    width: 100%;
    height: 92svh;
    border-radius: 22px 22px 0 0;
    transform: translateY(100%);
    transform-origin: bottom center;
    box-shadow: 0 -4px 32px rgba(0,0,0,0.15);
  }
  #vs-ai-chat-widget .ai-sheet.is-open {
    transform: translateY(0);
    opacity: 1;
  }
}

/* Drag handle */
#vs-ai-chat-widget .ai-drag-bar {
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 10px 0 4px;
  cursor: grab;
  flex-shrink: 0;
  touch-action: none;
}

#vs-ai-chat-widget .ai-drag-bar__nub {
  width: 40px;
  height: 4px;
  border-radius: 2px;
  background: rgba(0,0,0,0.12);
}

/* ---- Views ---- */
#vs-ai-chat-widget .ai-view {
  display: none;
  flex-direction: column;
  flex: 1;
  overflow: hidden;
  animation-duration: 0.28s;
  animation-fill-mode: both;
  animation-timing-function: cubic-bezier(0.32, 0.72, 0, 1);
}

#vs-ai-chat-widget .ai-view.is-active {
  display: flex !important;
}

#vs-ai-chat-widget .view-forward .ai-view.is-active {
  animation-name: vsaiSlideInRight;
}

#vs-ai-chat-widget .view-back .ai-view.is-active {
  animation-name: vsaiSlideInLeft;
}

@keyframes vsaiSlideInRight {
  from { transform: translateX(28px); opacity: 0; }
  to   { transform: translateX(0);    opacity: 1; }
}

@keyframes vsaiSlideInLeft {
  from { transform: translateX(-28px); opacity: 0; }
  to   { transform: translateX(0);     opacity: 1; }
}

/* ---- Sheet header (shared) ---- */
#vs-ai-chat-widget .ai-sheet__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px 10px;
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-sheet__logo {
  width: 30px;
  height: 30px;
  color: var(--vsai-primary);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-sheet__title {
  font-size: 16px;
  font-weight: 700;
  color: var(--vsai-text);
  flex: 1;
}

#vs-ai-chat-widget .ai-sheet__subtitle {
  font-size: 12px;
  color: var(--vsai-text-dim);
  flex: 1;
}

#vs-ai-chat-widget .ai-icon-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,0.06);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--vsai-text-dim);
  transition: background 0.18s, color 0.18s;
  flex-shrink: 0;
  padding: 0;
}

#vs-ai-chat-widget .ai-icon-btn:hover {
  background: rgba(0,0,0,0.09);
  color: var(--vsai-text);
}

#vs-ai-chat-widget .ai-icon-btn svg {
  width: 18px;
  height: 18px;
}

#vs-ai-chat-widget .ai-icon-btn--primary {
  background: rgba(31,224,122,0.15);
  color: var(--vsai-primary);
}

/* ========== DISCOVERY VIEW ========== */
#vs-ai-chat-widget .ai-discovery {
  padding: 0 16px 16px;
  overflow-y: auto;
  flex: 1;
}

#vs-ai-chat-widget .ai-discovery::-webkit-scrollbar { width: 0; }

#vs-ai-chat-widget .ai-discovery__search {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 0 14px;
  margin-bottom: 16px;
}

#vs-ai-chat-widget .ai-discovery__search input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--vsai-text);
  font-size: 14px;
  padding: 12px 0;
  font-family: inherit;
}

#vs-ai-chat-widget .ai-discovery__search input::placeholder { color: var(--vsai-text-muted); }

#vs-ai-chat-widget .ai-discovery__search-icon {
  width: 18px;
  height: 18px;
  color: var(--vsai-text-muted);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-discovery__search-btn {
  background: var(--vsai-primary);
  border: none;
  border-radius: 7px;
  padding: 6px 13px;
  font-size: 13px;
  font-weight: 600;
  color: #000;
  cursor: pointer;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-discovery__search-btn:hover { background: var(--vsai-primary-dk); }

/* Featured card */
#vs-ai-chat-widget .ai-featured-card {
  background: linear-gradient(135deg, #f0fdf6 0%, #e6f9ef 100%);
  border: 1px solid rgba(31,224,122,0.2);
  border-radius: var(--vsai-br);
  padding: 16px;
  margin-bottom: 16px;
  cursor: pointer;
  transition: border-color 0.18s, transform 0.18s;
}

#vs-ai-chat-widget .ai-featured-card:hover {
  border-color: rgba(31,224,122,0.45);
  transform: translateY(-1px);
}

#vs-ai-chat-widget .ai-featured-card__badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(31,224,122,0.15);
  color: var(--vsai-primary);
  border-radius: 20px;
  padding: 3px 10px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.4px;
  text-transform: uppercase;
  margin-bottom: 8px;
}

#vs-ai-chat-widget .ai-featured-card__title {
  font-size: 17px;
  font-weight: 700;
  color: var(--vsai-text);
  margin: 0 0 4px;
}

#vs-ai-chat-widget .ai-featured-card__desc {
  font-size: 13px;
  color: var(--vsai-text-dim);
  margin: 0;
}

/* 2×2 prompt grid */
#vs-ai-chat-widget .ai-prompts-section__title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--vsai-text-muted);
  margin: 0 0 10px;
}

#vs-ai-chat-widget .ai-prompts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 20px;
}

#vs-ai-chat-widget .ai-prompt-card {
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 12px;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s;
}

#vs-ai-chat-widget .ai-prompt-card:hover {
  border-color: rgba(31,224,122,0.3);
  background: var(--vsai-bg4);
}

#vs-ai-chat-widget .ai-prompt-card__label {
  font-size: 13px;
  font-weight: 700;
  color: var(--vsai-text);
  margin: 0 0 4px;
}

#vs-ai-chat-widget .ai-prompt-card__desc {
  font-size: 11px;
  color: var(--vsai-text-dim);
  margin: 0;
  line-height: 1.4;
}

/* Sessions */
#vs-ai-chat-widget .ai-sessions-section__title {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--vsai-text-muted);
  margin: 0 0 10px;
}

#vs-ai-chat-widget .ai-sessions-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: 72px;
}

#vs-ai-chat-widget .ai-session-row {
  display: flex;
  align-items: center;
  gap: 10px;
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 10px 12px;
  cursor: pointer;
  transition: border-color 0.18s;
}

#vs-ai-chat-widget .ai-session-row:hover { border-color: rgba(31,224,122,0.25); }

#vs-ai-chat-widget .ai-session-row__icon {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(31,224,122,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--vsai-primary);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-session-row__icon svg { width: 15px; height: 15px; }

#vs-ai-chat-widget .ai-session-row__body { flex: 1; overflow: hidden; }

#vs-ai-chat-widget .ai-session-row__label {
  font-size: 13px;
  font-weight: 600;
  color: var(--vsai-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin: 0 0 2px;
}

#vs-ai-chat-widget .ai-session-row__time {
  font-size: 11px;
  color: var(--vsai-text-muted);
  margin: 0;
}

#vs-ai-chat-widget .ai-session-row__del {
  background: none;
  border: none;
  color: var(--vsai-text-muted);
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: color 0.18s;
}

#vs-ai-chat-widget .ai-session-row__del:hover { color: #f87171; }
#vs-ai-chat-widget .ai-session-row__del svg { width: 15px; height: 15px; }

/* View-betslip pinned btn */
#vs-ai-chat-widget .ai-view-betslip-wrap {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 12px 16px 20px;
  background: linear-gradient(to top, var(--vsai-bg) 70%, transparent);
  display: flex;
  gap: 10px;
  align-items: center;
}

#vs-ai-chat-widget .ai-view-betslip-btn {
  flex: 1;
  background: var(--vsai-primary);
  border: none;
  border-radius: var(--vsai-br-sm);
  padding: 13px 16px;
  font-size: 14px;
  font-weight: 700;
  color: #000;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-view-betslip-btn:hover { background: var(--vsai-primary-dk); }
#vs-ai-chat-widget .ai-view-betslip-btn svg { width: 18px; height: 18px; }

#vs-ai-chat-widget .ai-view-betslip-wrap.is-hidden { display: none; }

/* Quota bar */
#vs-ai-chat-widget .ai-quota-bar {
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 10px 14px;
  margin: 0 0 14px;
}

#vs-ai-chat-widget .ai-quota-bar__row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 6px;
}

#vs-ai-chat-widget .ai-quota-bar__label { font-size: 11px; color: var(--vsai-text-dim); }
#vs-ai-chat-widget .ai-quota-bar__count { font-size: 11px; font-weight: 700; color: var(--vsai-primary); }

#vs-ai-chat-widget .ai-quota-bar__track {
  height: 4px;
  background: var(--vsai-bg4);
  border-radius: 2px;
  overflow: hidden;
}

#vs-ai-chat-widget .ai-quota-bar__fill {
  height: 100%;
  background: var(--vsai-primary);
  border-radius: 2px;
  transition: width 0.4s;
}

#vs-ai-chat-widget .ai-quota-bar.is-hidden { display: none; }

/* ========== LOADING VIEW ========== */
#vs-ai-chat-widget .ai-loading {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 28px;
  padding: 32px;
}

#vs-ai-chat-widget .ai-loading__orb-wrap {
  position: relative;
  width: 90px;
  height: 90px;
  display: flex;
  align-items: center;
  justify-content: center;
}

#vs-ai-chat-widget .ai-loading__ring {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--vsai-primary);
  animation: vsaiSpin 1.1s linear infinite;
}

#vs-ai-chat-widget .ai-loading__ring--outer {
  inset: -8px;
  border-top-color: rgba(31,224,122,0.3);
  animation-duration: 1.8s;
  animation-direction: reverse;
}

@keyframes vsaiSpin { to { transform: rotate(360deg); } }

#vs-ai-chat-widget .ai-loading__orb {
  width: 58px;
  height: 58px;
  border-radius: 50%;
  background: radial-gradient(circle at 38% 38%, rgba(31,224,122,0.55) 0%, rgba(31,224,122,0.08) 70%);
  animation: vsaiPulse 2s ease-in-out infinite;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--vsai-primary);
}

#vs-ai-chat-widget .ai-loading__orb svg { width: 28px; height: 28px; }

@keyframes vsaiPulse {
  0%, 100% { transform: scale(1);    opacity: 1;    box-shadow: 0 0 0 0 rgba(31,224,122,0.25); }
  50%       { transform: scale(1.07); opacity: 0.9; box-shadow: 0 0 0 12px rgba(31,224,122,0); }
}

#vs-ai-chat-widget .ai-loading__phrase {
  font-size: 16px;
  font-weight: 600;
  color: var(--vsai-text-dim);
  text-align: center;
  transition: opacity 0.4s;
}

/* ========== RESULTS VIEW ========== */
#vs-ai-chat-widget .ai-view--results {
  overflow: hidden;
  background: var(--vsai-bg);
}

#vs-ai-chat-widget .ai-results__header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px 10px;
  flex-shrink: 0;
  border-bottom: 1px solid var(--vsai-border);
}

#vs-ai-chat-widget .ai-results__body {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
}

#vs-ai-chat-widget .ai-results__body::-webkit-scrollbar { width: 0; }

#vs-ai-chat-widget .ai-results__summary {
  font-size: 13px;
  color: var(--vsai-text-dim);
  margin: 0 0 16px;
  line-height: 1.5;
}

#vs-ai-chat-widget .ai-ranked-row {
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br);
  padding: 14px;
  margin-bottom: 10px;
  transition: border-color 0.18s;
}

#vs-ai-chat-widget .ai-ranked-row:hover { border-color: rgba(31,224,122,0.25); }

#vs-ai-chat-widget .ai-ranked-row__top {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}

#vs-ai-chat-widget .ai-ranked-row__num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(31,224,122,0.15);
  color: var(--vsai-primary);
  font-size: 11px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
}

#vs-ai-chat-widget .ai-ranked-row__info { flex: 1; }

#vs-ai-chat-widget .ai-ranked-row__fixture {
  font-size: 11px;
  color: var(--vsai-text-muted);
  margin: 0 0 3px;
}

#vs-ai-chat-widget .ai-ranked-row__outcome {
  font-size: 14px;
  font-weight: 700;
  color: var(--vsai-text);
  margin: 0 0 2px;
}

#vs-ai-chat-widget .ai-ranked-row__market {
  font-size: 11px;
  color: var(--vsai-text-dim);
  margin: 0;
}

#vs-ai-chat-widget .ai-ranked-row__odds {
  font-size: 18px;
  font-weight: 800;
  color: var(--vsai-primary);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-confidence {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}

#vs-ai-chat-widget .ai-confidence__label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--vsai-text-muted);
  white-space: nowrap;
}

#vs-ai-chat-widget .ai-confidence__track {
  flex: 1;
  height: 4px;
  background: var(--vsai-bg4);
  border-radius: 2px;
  overflow: hidden;
}

#vs-ai-chat-widget .ai-confidence__fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
}

#vs-ai-chat-widget .ai-confidence__pct {
  font-size: 10px;
  font-weight: 700;
  white-space: nowrap;
}

#vs-ai-chat-widget .ai-ranked-row__reason {
  font-size: 12px;
  color: var(--vsai-text-dim);
  margin: 0 0 10px;
  line-height: 1.45;
}

#vs-ai-chat-widget .ai-ranked-row__actions {
  display: flex;
  gap: 8px;
}

#vs-ai-chat-widget .ai-add-btn {
  flex: 1;
  border: 1px solid var(--vsai-primary);
  background: rgba(31,224,122,0.08);
  color: var(--vsai-primary);
  border-radius: var(--vsai-br-sm);
  padding: 8px 12px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-add-btn:hover { background: rgba(31,224,122,0.16); }

#vs-ai-chat-widget .ai-add-btn.is-added {
  background: rgba(31,224,122,0.18);
  border-color: var(--vsai-primary);
}

#vs-ai-chat-widget .ai-add-btn svg { width: 14px; height: 14px; }

/* Suggest-another-leg btn */
#vs-ai-chat-widget .ai-suggest-leg-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  background: var(--vsai-bg3);
  border: 1px dashed rgba(31,224,122,0.35);
  color: var(--vsai-primary);
  border-radius: var(--vsai-br-sm);
  padding: 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 6px;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-suggest-leg-btn:hover { background: var(--vsai-bg4); }
#vs-ai-chat-widget .ai-suggest-leg-btn svg { width: 16px; height: 16px; }

/* Follow-up btn */
#vs-ai-chat-widget .ai-followup-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  background: rgba(31,224,122,0.1);
  border: 1px solid rgba(31,224,122,0.25);
  color: var(--vsai-primary);
  border-radius: var(--vsai-br-sm);
  padding: 11px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 10px;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-followup-btn:hover { background: rgba(31,224,122,0.18); }
#vs-ai-chat-widget .ai-followup-btn svg { width: 16px; height: 16px; }

/* ========== CHAT VIEW ========== */
#vs-ai-chat-widget .ai-view--chat {
  background: var(--vsai-bg);
}

#vs-ai-chat-widget .ai-chat__header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 8px;
  border-bottom: 1px solid var(--vsai-border);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-chat__logo {
  width: 26px;
  height: 26px;
  color: var(--vsai-primary);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-chat__title-block { flex: 1; overflow: hidden; }

#vs-ai-chat-widget .ai-chat__title {
  font-size: 13px;
  font-weight: 700;
  margin: 0 0 1px;
}

#vs-ai-chat-widget .ai-chat__status {
  font-size: 11px;
  color: var(--vsai-text-muted);
  margin: 0;
}

#vs-ai-chat-widget .ai-chat__status--thinking {
  color: var(--vsai-primary);
  animation: vsaiStatusBlink 1.2s ease-in-out infinite;
}

@keyframes vsaiStatusBlink {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}

/* Messages */
#vs-ai-chat-widget .ai-messages {
  flex: 1;
  overflow-y: auto;
  padding: 14px 14px 4px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  scroll-behavior: smooth;
}

#vs-ai-chat-widget .ai-messages::-webkit-scrollbar { width: 0; }

#vs-ai-chat-widget .ai-message {
  display: flex;
  flex-direction: column;
  max-width: 88%;
}

#vs-ai-chat-widget .ai-message--user {
  align-self: flex-end;
  align-items: flex-end;
}

#vs-ai-chat-widget .ai-message--assistant {
  align-self: flex-start;
  align-items: flex-start;
}

#vs-ai-chat-widget .ai-bubble {
  padding: 10px 13px;
  border-radius: 16px;
  font-size: 13px;
  line-height: 1.5;
  max-width: 100%;
  word-break: break-word;
}

#vs-ai-chat-widget .ai-message--user .ai-bubble {
  background: var(--vsai-primary);
  color: #000;
  border-bottom-right-radius: 4px;
}

#vs-ai-chat-widget .ai-message--assistant .ai-bubble {
  background: var(--vsai-bg3);
  color: var(--vsai-text);
  border-bottom-left-radius: 4px;
  border: 1px solid var(--vsai-border);
}

/* Markdown bubble */
#vs-ai-chat-widget .ai-bubble--md { padding: 10px 14px; }
#vs-ai-chat-widget .ai-bubble--md p { margin: 0 0 6px; }
#vs-ai-chat-widget .ai-bubble--md p:last-child { margin-bottom: 0; }
#vs-ai-chat-widget .ai-bubble--md ul, #vs-ai-chat-widget .ai-bubble--md ol { margin: 4px 0 4px 16px; padding: 0; }
#vs-ai-chat-widget .ai-bubble--md li { margin-bottom: 2px; }
#vs-ai-chat-widget .ai-bubble--md strong { color: var(--vsai-primary); }
#vs-ai-chat-widget .ai-bubble--md a { color: var(--vsai-primary); }

/* Typing dots */
#vs-ai-chat-widget .ai-bubble--typing {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 12px 16px;
}

#vs-ai-chat-widget .ai-typing-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--vsai-text-dim);
  animation: vsaiTypingDot 1.2s ease-in-out infinite;
}

#vs-ai-chat-widget .ai-typing-dot:nth-child(2) { animation-delay: 0.2s; }
#vs-ai-chat-widget .ai-typing-dot:nth-child(3) { animation-delay: 0.4s; }

@keyframes vsaiTypingDot {
  0%, 80%, 100% { transform: scale(0.7); opacity: 0.4; }
  40%           { transform: scale(1);   opacity: 1; }
}

/* Pick card inside chat */
#vs-ai-chat-widget .ai-pick-card {
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br);
  padding: 12px;
  margin-top: 6px;
  width: 100%;
}

#vs-ai-chat-widget .ai-pick-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}

#vs-ai-chat-widget .ai-pick-card__outcome {
  font-size: 13px;
  font-weight: 700;
  color: var(--vsai-text);
}

#vs-ai-chat-widget .ai-pick-card__odds {
  font-size: 15px;
  font-weight: 800;
  color: var(--vsai-primary);
}

#vs-ai-chat-widget .ai-pick-card__fixture {
  font-size: 11px;
  color: var(--vsai-text-muted);
  margin: 0 0 6px;
}

#vs-ai-chat-widget .ai-pick-card__actions {
  display: flex;
  gap: 7px;
  margin-top: 8px;
}

/* Result card */
#vs-ai-chat-widget .ai-result-card {
  background: #fff;
  border: 1px solid rgba(0,0,0,0.08);
  border-radius: var(--vsai-br);
  padding: 14px;
  margin-top: 6px;
  width: 100%;
}

#vs-ai-chat-widget .ai-result-card__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--vsai-primary);
  margin: 0 0 6px;
}

#vs-ai-chat-widget .ai-result-card__body {
  font-size: 12px;
  color: var(--vsai-text-dim);
  line-height: 1.5;
  margin: 0;
}

/* Suggestion chips */
#vs-ai-chat-widget .ai-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 8px;
}

#vs-ai-chat-widget .ai-chip {
  background: rgba(31,224,122,0.09);
  border: 1px solid rgba(31,224,122,0.28);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--vsai-primary);
  cursor: pointer;
  transition: background 0.18s;
  white-space: nowrap;
}

#vs-ai-chat-widget .ai-chip:hover { background: rgba(31,224,122,0.18); }

/* Chat input footer */
#vs-ai-chat-widget .ai-chat__footer {
  padding: 10px 12px 14px;
  border-top: 1px solid var(--vsai-border);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-input-row {
  display: flex;
  align-items: flex-end;
  gap: 8px;
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: 22px;
  padding: 4px 8px 4px 14px;
  transition: border-color 0.18s;
}

#vs-ai-chat-widget .ai-input-row:focus-within {
  border-color: rgba(31,224,122,0.4);
}

#vs-ai-chat-widget .ai-chat__input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: var(--vsai-text);
  font-size: 14px;
  font-family: inherit;
  resize: none;
  max-height: 120px;
  padding: 7px 0;
  line-height: 1.4;
  overflow-y: auto;
}

#vs-ai-chat-widget .ai-chat__input::placeholder { color: var(--vsai-text-muted); }

#vs-ai-chat-widget .ai-chat__send {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--vsai-primary);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: #000;
  flex-shrink: 0;
  transition: background 0.18s, opacity 0.18s;
}

#vs-ai-chat-widget .ai-chat__send:disabled {
  opacity: 0.45;
  cursor: not-allowed;
}

#vs-ai-chat-widget .ai-chat__send svg { width: 16px; height: 16px; }

/* Limit gate */
#vs-ai-chat-widget .ai-limit-gate {
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 12px 14px;
  text-align: center;
}

#vs-ai-chat-widget .ai-limit-gate.is-hidden { display: none; }
#vs-ai-chat-widget .ai-input-row.is-hidden  { display: none; }

#vs-ai-chat-widget .ai-limit-gate__title {
  font-size: 13px;
  font-weight: 700;
  color: var(--vsai-text);
  margin: 0 0 4px;
}

#vs-ai-chat-widget .ai-limit-gate__desc {
  font-size: 12px;
  color: var(--vsai-text-dim);
  margin: 0 0 10px;
  line-height: 1.4;
}

#vs-ai-chat-widget .ai-limit-gate__btn {
  display: inline-block;
  background: var(--vsai-primary);
  color: #000;
  border: none;
  border-radius: 8px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-limit-gate__btn:hover { background: var(--vsai-primary-dk); }

/* ========== SLIP BAR ========== */
#vs-ai-chat-widget .ai-slip-bar {
  margin: 0 12px 10px;
  background: var(--vsai-bg3);
  border: 1px solid rgba(31,224,122,0.3);
  border-radius: var(--vsai-br-sm);
  display: flex;
  align-items: center;
  padding: 10px 14px;
  gap: 10px;
  cursor: pointer;
  transition: border-color 0.18s;
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-slip-bar:hover { border-color: rgba(31,224,122,0.55); }
#vs-ai-chat-widget .ai-slip-bar.is-hidden { display: none; }

#vs-ai-chat-widget .ai-slip-bar__icon { color: var(--vsai-primary); flex-shrink: 0; }
#vs-ai-chat-widget .ai-slip-bar__icon svg { width: 18px; height: 18px; }

#vs-ai-chat-widget .ai-slip-bar__body { flex: 1; }

#vs-ai-chat-widget .ai-slip-bar__label {
  font-size: 12px;
  font-weight: 600;
  color: var(--vsai-text);
  margin: 0 0 2px;
}

#vs-ai-chat-widget .ai-slip-bar__sub {
  font-size: 11px;
  color: var(--vsai-text-muted);
  margin: 0;
}

#vs-ai-chat-widget .ai-slip-bar__odds {
  font-size: 16px;
  font-weight: 800;
  color: var(--vsai-primary);
}

/* ========== BETSLIP OVERLAY ========== */
#vs-ai-chat-widget .ai-betslip-overlay {
  position: absolute;
  inset: 0;
  z-index: 10;
  background: var(--vsai-bg);
  border-radius: 22px 22px 0 0;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.38s cubic-bezier(0.32, 0.72, 0, 1);
  overflow: hidden;
}

#vs-ai-chat-widget .ai-betslip-overlay.is-open {
  transform: translateY(0);
}

#vs-ai-chat-widget .ai-betslip-overlay__header {
  display: flex;
  align-items: center;
  padding: 14px 16px 10px;
  gap: 10px;
  flex-shrink: 0;
  border-bottom: 1px solid var(--vsai-border);
}

#vs-ai-chat-widget .ai-betslip-overlay__title {
  flex: 1;
  font-size: 16px;
  font-weight: 700;
}

#vs-ai-chat-widget .ai-betslip-overlay__body {
  flex: 1;
  overflow-y: auto;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

#vs-ai-chat-widget .ai-betslip-overlay__body::-webkit-scrollbar { width: 0; }

/* Hero stake card */
#vs-ai-chat-widget .ai-betslip-hero {
  background: linear-gradient(135deg, #f0fdf6 0%, #e6f9ef 100%);
  border: 1px solid rgba(31,224,122,0.25);
  border-radius: var(--vsai-br);
  padding: 18px;
}

#vs-ai-chat-widget .ai-betslip-hero__label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--vsai-text-dim);
  margin: 0 0 8px;
}

#vs-ai-chat-widget .ai-stake-input-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

#vs-ai-chat-widget .ai-stake-input-wrap span {
  font-size: 22px;
  font-weight: 700;
  color: var(--vsai-text-dim);
}

#vs-ai-chat-widget .ai-stake-input {
  flex: 1;
  background: none;
  border: none;
  border-bottom: 2px solid rgba(31,224,122,0.4);
  outline: none;
  font-size: 26px;
  font-weight: 700;
  color: var(--vsai-text);
  font-family: inherit;
  padding: 4px 0;
  max-width: 140px;
}

#vs-ai-chat-widget .ai-stake-presets {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}

#vs-ai-chat-widget .ai-preset-btn {
  background: rgba(0,0,0,0.06);
  border: 1px solid var(--vsai-border);
  border-radius: 6px;
  padding: 5px 11px;
  font-size: 12px;
  font-weight: 600;
  color: var(--vsai-text-dim);
  cursor: pointer;
  transition: background 0.18s, color 0.18s;
}

#vs-ai-chat-widget .ai-preset-btn:hover {
  background: rgba(0,0,0,0.09);
  color: var(--vsai-text);
}

#vs-ai-chat-widget .ai-betslip-hero__returns {
  display: flex;
  gap: 20px;
}

#vs-ai-chat-widget .ai-returns-item { flex: 1; }

#vs-ai-chat-widget .ai-returns-item__label {
  font-size: 11px;
  color: var(--vsai-text-dim);
  margin: 0 0 3px;
}

#vs-ai-chat-widget .ai-returns-item__val {
  font-size: 18px;
  font-weight: 800;
  color: var(--vsai-primary);
  margin: 0;
}

/* Bookie picker */
#vs-ai-chat-widget .ai-bookie-section__title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--vsai-text-muted);
  margin: 0 0 10px;
  font-weight: 600;
}

#vs-ai-chat-widget .ai-bookie-cards {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding-bottom: 4px;
}

#vs-ai-chat-widget .ai-bookie-cards::-webkit-scrollbar { height: 0; }

#vs-ai-chat-widget .ai-bookie-card {
  flex-shrink: 0;
  width: 100px;
  background: var(--vsai-bg3);
  border: 2px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 10px;
  cursor: pointer;
  transition: border-color 0.18s, transform 0.18s;
  position: relative;
  text-align: center;
}

#vs-ai-chat-widget .ai-bookie-card:hover { transform: translateY(-1px); }

#vs-ai-chat-widget .ai-bookie-card.is-selected {
  border-color: var(--bookie-accent, var(--vsai-primary));
}

#vs-ai-chat-widget .ai-bookie-card__mark {
  font-size: 15px;
  font-weight: 900;
  color: var(--bookie-accent, var(--vsai-primary));
  margin: 0 0 5px;
  font-family: serif;
}

#vs-ai-chat-widget .ai-bookie-card__name {
  font-size: 10px;
  color: var(--vsai-text-dim);
  margin: 0 0 4px;
}

#vs-ai-chat-widget .ai-bookie-card__odds {
  font-size: 13px;
  font-weight: 800;
  color: var(--vsai-text);
  margin: 0;
}

#vs-ai-chat-widget .ai-bookie-card__best {
  position: absolute;
  top: -7px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--vsai-primary);
  color: #000;
  font-size: 9px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

#vs-ai-chat-widget .ai-bookie-card__uncovered {
  font-size: 10px;
  color: var(--vsai-text-muted);
  margin: 0;
}

/* Slip selections */
#vs-ai-chat-widget .ai-slip-section__title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: var(--vsai-text-muted);
  margin: 0 0 10px;
  font-weight: 600;
}

#vs-ai-chat-widget .ai-slip-items { display: flex; flex-direction: column; gap: 8px; }

#vs-ai-chat-widget .ai-slip-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: var(--vsai-bg3);
  border: 1px solid var(--vsai-border);
  border-radius: var(--vsai-br-sm);
  padding: 10px 12px;
}

#vs-ai-chat-widget .ai-slip-item__num {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: rgba(31,224,122,0.13);
  color: var(--vsai-primary);
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
}

#vs-ai-chat-widget .ai-slip-item__body { flex: 1; overflow: hidden; }

#vs-ai-chat-widget .ai-slip-item__match {
  font-size: 10px;
  color: var(--vsai-text-muted);
  margin: 0 0 2px;
}

#vs-ai-chat-widget .ai-slip-item__selection {
  font-size: 13px;
  font-weight: 700;
  color: var(--vsai-text);
  margin: 0 0 1px;
}

#vs-ai-chat-widget .ai-slip-item__market {
  font-size: 11px;
  color: var(--vsai-text-dim);
  margin: 0;
}

#vs-ai-chat-widget .ai-slip-item__odds {
  font-size: 15px;
  font-weight: 800;
  color: var(--vsai-primary);
}

#vs-ai-chat-widget .ai-slip-item__remove {
  background: none;
  border: none;
  color: var(--vsai-text-muted);
  cursor: pointer;
  padding: 3px;
  display: flex;
  align-items: center;
  transition: color 0.18s;
}

#vs-ai-chat-widget .ai-slip-item__remove:hover { color: #f87171; }
#vs-ai-chat-widget .ai-slip-item__remove svg { width: 14px; height: 14px; }

#vs-ai-chat-widget .ai-slip-combined {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--vsai-bg4);
  border-radius: var(--vsai-br-sm);
  padding: 10px 14px;
  margin-top: 4px;
}

#vs-ai-chat-widget .ai-slip-combined__label {
  font-size: 12px;
  color: var(--vsai-text-dim);
}

#vs-ai-chat-widget .ai-slip-combined__odds {
  font-size: 16px;
  font-weight: 800;
  color: var(--vsai-primary);
}

/* Betslip footer CTA */
#vs-ai-chat-widget .ai-betslip-footer {
  padding: 12px 16px 20px;
  border-top: 1px solid var(--vsai-border);
  flex-shrink: 0;
}

#vs-ai-chat-widget .ai-place-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  background: var(--vsai-primary);
  color: #000;
  border: none;
  border-radius: var(--vsai-br-sm);
  padding: 14px 20px;
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.18s;
}

#vs-ai-chat-widget .ai-place-btn:hover { background: var(--vsai-primary-dk); }
#vs-ai-chat-widget .ai-place-btn svg { width: 18px; height: 18px; }

#vs-ai-chat-widget .ai-clear-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 100%;
  background: none;
  border: 1px solid var(--vsai-border);
  color: var(--vsai-text-muted);
  border-radius: var(--vsai-br-sm);
  padding: 10px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 8px;
  transition: color 0.18s, border-color 0.18s;
}

#vs-ai-chat-widget .ai-clear-btn:hover {
  color: #f87171;
  border-color: rgba(248,113,113,0.4);
}

/* ========== TOAST ========== */
#vs-ai-chat-widget .ai-toast {
  position: absolute;
  top: 56px;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  z-index: 20;
  background: var(--vsai-bg4);
  border: 1px solid var(--vsai-border);
  border-radius: 20px;
  padding: 8px 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--vsai-text);
  white-space: nowrap;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.22s, transform 0.22s;
}

#vs-ai-chat-widget .ai-toast.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

#vs-ai-chat-widget .ai-toast--add  { border-color: rgba(31,224,122,0.45); color: var(--vsai-primary); }
#vs-ai-chat-widget .ai-toast--remove { border-color: rgba(248,113,113,0.35); color: #f87171; }

/* ========== Empty states ========== */
#vs-ai-chat-widget .ai-sessions-empty {
  font-size: 13px;
  color: var(--vsai-text-muted);
  text-align: center;
  padding: 12px 0;
}

#vs-ai-chat-widget .ai-betslip-empty {
  text-align: center;
  color: var(--vsai-text-muted);
  font-size: 13px;
  padding: 16px 0;
}
