/* ── FLIPO Chat Widget — v2.0 Tradentry brand edition ───────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Sora:wght@600;700;800&display=swap');


:root {
  --tc-bg-dark:        #040912;
  --tc-bg-panel:       rgba(10, 22, 40, .92);
  --tc-bg-header:      rgba(13, 28, 50, .85);
  --tc-bg-input:       rgba(19, 36, 61, .65);
  --tc-bg-msg-user:    linear-gradient(135deg, #00e5ff 0%, #4dd6e8 50%, #5cf2ff 100%);
  --tc-bg-msg-bot:     linear-gradient(180deg, rgba(19,36,61,.85) 0%, rgba(15,30,52,.85) 100%);
  --tc-bg-msg-agent:   linear-gradient(135deg, rgba(0,229,255,.16) 0%, rgba(34,197,94,.10) 100%);
  --tc-border:         rgba(77,214,232,.18);
  --tc-border-soft:    rgba(255,255,255,.06);
  --tc-border-glow:    rgba(0,229,255,.35);
  --tc-accent:         #00e5ff;
  --tc-accent-2:       #5cf2ff;
  --tc-accent-grad:    linear-gradient(135deg, #00e5ff 0%, #4dd6e8 50%, #5cf2ff 100%);
  --tc-accent-hover:   #5cf2ff;
  --tc-text:           #e2eaf5;
  --tc-text-muted:     #8ea3c2;
  --tc-text-white:     #f1f8ff;
  --tc-text-on-accent: #051422;
  --tc-success:        #22e69a;
  --tc-warning:        #ffab00;
  --tc-danger:         #ff5252;
  --tc-radius:         18px;
  --tc-radius-sm:      10px;
  --tc-fab-size:       68px;
  --tc-panel-w:        400px;
  --tc-panel-h:        620px;
  --tc-font:           "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --tc-font-heading:   "Sora", "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
  --tc-z:              999999;
  --tc-shadow-fab:     0 8px 24px rgba(0,229,255,.45), 0 4px 14px rgba(0,229,255,.25), 0 2px 8px rgba(0,0,0,.4);
  --tc-shadow-panel:   0 24px 60px rgba(0,0,0,.6), 0 8px 24px rgba(0,229,255,.08), 0 0 0 1px rgba(77,214,232,.12);
}

/* ── Floating action button ──────────────────────────────────────────── */
.tradentry-fab {
  position: fixed;
  bottom: 28px;
  right: 28px;
  z-index: var(--tc-z);
  width: var(--tc-fab-size);
  height: var(--tc-fab-size);
  border-radius: 50%;
  background: var(--tc-accent-grad);
  color: var(--tc-text-on-accent);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--tc-shadow-fab);
  transition: transform .25s cubic-bezier(.34,1.56,.64,1), box-shadow .25s ease, filter .25s ease;
  padding: 0;
  font-family: var(--tc-font);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  animation: tc-pulse 2.6s cubic-bezier(.4,0,.6,1) infinite;
}
.tradentry-fab::before {
  content: '';
  position: absolute;
  inset: -8px;
  border-radius: 50%;
  background: var(--tc-accent-grad);
  opacity: .55;
  filter: blur(18px);
  z-index: -1;
  animation: tc-halo 2.6s cubic-bezier(.4,0,.6,1) infinite;
}
.tradentry-fab::after {
  content: '';
  position: absolute;
  inset: 2px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.25);
  pointer-events: none;
}
.tradentry-fab:hover  {
  transform: translateY(-3px) scale(1.06);
  filter: brightness(1.08);
  box-shadow: 0 14px 32px rgba(0,229,255,.55), 0 6px 18px rgba(0,229,255,.35), 0 2px 8px rgba(0,0,0,.4);
}
.tradentry-fab:active { transform: scale(.95); }
.tradentry-fab:focus-visible {
  outline: 3px solid rgba(0,229,255,.6);
  outline-offset: 5px;
}
.tradentry-fab__logo  {
  width: 72%; height: 72%;
  object-fit: contain;
  pointer-events: none;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,.25));
}

@keyframes tc-pulse {
  0%   { box-shadow: var(--tc-shadow-fab), 0 0 0 0 rgba(0,229,255,.6); }
  70%  { box-shadow: var(--tc-shadow-fab), 0 0 0 22px rgba(0,229,255,0); }
  100% { box-shadow: var(--tc-shadow-fab), 0 0 0 0 rgba(0,229,255,0); }
}
@keyframes tc-halo {
  0%, 100% { opacity: .55; transform: scale(1); }
  50%      { opacity: .85; transform: scale(1.08); }
}

/* ── Panel ──────────────────────────────────────────────────────────── */
.tradentry-panel {
  position: fixed;
  bottom: 110px;
  right: 28px;
  z-index: var(--tc-z);
  width: var(--tc-panel-w);
  max-width: calc(100vw - 32px);
  height: var(--tc-panel-h);
  max-height: calc(100vh - 140px);
  background: var(--tc-bg-panel);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border: 1px solid var(--tc-border);
  border-radius: var(--tc-radius);
  display: flex;
  flex-direction: column;
  box-shadow: var(--tc-shadow-panel);
  overflow: hidden;
  font-family: var(--tc-font);
  color: var(--tc-text);
  animation: tc-slide-in .35s cubic-bezier(.34,1.56,.64,1);
}
.tradentry-panel::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--tc-accent-grad);
  filter: blur(.5px);
  pointer-events: none;
}
.tradentry-panel--inline {
  position: relative; bottom: auto; right: auto;
  width: 100%; height: 540px; margin: 0 auto;
}

@keyframes tc-slide-in {
  from { opacity: 0; transform: translateY(12px) scale(.98); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ── Header ─────────────────────────────────────────────────────────── */
.tradentry-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  background: var(--tc-bg-header);
  border-bottom: 1px solid var(--tc-border);
  position: relative;
}
.tradentry-header::after {
  content: '';
  position: absolute;
  left: 16px; right: 16px; bottom: -1px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(0,229,255,.5), transparent);
}
.tradentry-header__logo {
  width: 36px; height: 36px;
  object-fit: contain;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(0,229,255,.18), rgba(92,242,255,.08));
  padding: 5px;
  border: 1px solid rgba(0,229,255,.25);
  box-shadow: 0 0 14px rgba(0,229,255,.2);
}
.tradentry-title {
  flex: 1;
  font-family: var(--tc-font-heading);
  font-weight: 800;
  font-size: 16px;
  color: var(--tc-text-white);
  letter-spacing: .03em;
}
.tradentry-title::before {
  content: '';
  display: inline-block;
  width: 8px; height: 8px;
  background: var(--tc-success);
  border-radius: 50%;
  margin-right: 8px;
  box-shadow: 0 0 6px var(--tc-success);
  vertical-align: 1px;
}
.tradentry-close {
  background: transparent;
  border: none;
  color: var(--tc-text-muted);
  font-size: 22px;
  cursor: pointer;
  width: 32px; height: 32px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, color .15s;
}
.tradentry-close:hover { background: rgba(255,255,255,.08); color: var(--tc-text-white); }

/* ── Status bar (top) ───────────────────────────────────────────────── */
.tradentry-status {
  background: linear-gradient(90deg, rgba(34,197,94,.15) 0%, rgba(34,197,94,.05) 100%);
  color: var(--tc-success);
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  padding: 8px 14px;
  letter-spacing: .02em;
  border-bottom: 1px solid rgba(34,197,94,.2);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  animation: tc-fade-in .3s ease;
}
.tradentry-status::before {
  content: '';
  width: 8px; height: 8px;
  background: var(--tc-success);
  border-radius: 50%;
  animation: tc-blink 1.5s ease-in-out infinite;
}
@keyframes tc-blink { 50% { opacity: .3; } }
@keyframes tc-fade-in { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }

/* ── Messages list ──────────────────────────────────────────────────── */
.tradentry-messages {
  flex: 1;
  overflow-y: auto;
  padding: 18px;
  background:
    radial-gradient(ellipse 80% 50% at 100% 0%, rgba(0,229,255,.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 0% 100%, rgba(92,242,255,.06) 0%, transparent 60%),
    linear-gradient(180deg, rgba(7,15,29,.6) 0%, rgba(4,9,18,.6) 100%);
  scrollbar-width: thin;
  scrollbar-color: rgba(0,229,255,.3) transparent;
}
.tradentry-messages::-webkit-scrollbar { width: 6px; }
.tradentry-messages::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(0,229,255,.4), rgba(92,242,255,.2));
  border-radius: 3px;
}
.tradentry-messages::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(0,229,255,.7), rgba(92,242,255,.4));
}

/* ── Message bubbles ────────────────────────────────────────────────── */
.tradentry-msg {
  margin-bottom: 12px;
  max-width: 85%;
  animation: tc-msg-in .25s ease-out;
}
@keyframes tc-msg-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}
.tradentry-msg__name {
  display: block;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--tc-text-muted);
  margin-bottom: 4px;
  font-weight: 600;
}
.tradentry-msg__body {
  margin: 0;
  padding: 11px 14px;
  border-radius: var(--tc-radius-sm);
  font-size: 13px;
  line-height: 1.5;
  word-wrap: break-word;
  white-space: pre-wrap;
}
.tradentry-msg__body strong { color: var(--tc-text-white); font-weight: 700; }
.tradentry-msg__body em     { color: var(--tc-text); font-style: italic; }
.tradentry-msg__body code   {
  background: rgba(255,255,255,.08);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: 'SFMono-Regular', Consolas, monospace;
  font-size: 12px;
}
.tradentry-md__list { margin: 4px 0 0; padding-left: 22px; }
.tradentry-md__list li { margin-bottom: 4px; }

/* ── User bubble (right-aligned) ─────────────────────────────────────── */
.tradentry-msg--user {
  margin-left: auto;
  text-align: right;
}
.tradentry-msg--user .tradentry-msg__name { display: none; }
.tradentry-msg--user .tradentry-msg__body {
  display: inline-block;
  background: var(--tc-bg-msg-user);
  color: var(--tc-text-on-accent);
  font-weight: 600;
  border-bottom-right-radius: 4px;
  text-align: left;
  box-shadow: 0 6px 18px rgba(0,229,255,.3), 0 2px 6px rgba(0,229,255,.18);
}
.tradentry-msg--user .tradentry-msg__body strong { color: #02101c; }

/* ── Bot bubble ──────────────────────────────────────────────────────── */
.tradentry-msg--assistant .tradentry-msg__body {
  background: var(--tc-bg-msg-bot);
  color: var(--tc-text);
  border-bottom-left-radius: 4px;
  border: 1px solid var(--tc-border);
  box-shadow: 0 2px 12px rgba(0,0,0,.25), inset 0 1px 0 rgba(255,255,255,.03);
}
.tradentry-msg--assistant .tradentry-msg__name {
  color: var(--tc-accent);
  font-weight: 700;
  text-shadow: 0 0 10px rgba(0,229,255,.4);
}

/* ── Agent bubble ────────────────────────────────────────────────────── */
.tradentry-msg--agent .tradentry-msg__body {
  background: var(--tc-bg-msg-agent);
  color: var(--tc-text);
  border-bottom-left-radius: 3px;
  border: 1px solid rgba(34,197,94,.25);
}
.tradentry-msg--agent .tradentry-msg__name {
  color: var(--tc-success);
}
.tradentry-msg--agent .tradentry-msg__name::before {
  content: '👤 ';
  margin-right: 2px;
}

/* ── System (event) lines ────────────────────────────────────────────── */
.tradentry-msg--system {
  margin: 8px auto;
  font-size: 10.5px;
  text-align: center;
  color: var(--tc-text-muted);
  font-style: italic;
  padding: 4px 12px;
  background: rgba(255,255,255,.03);
  border-radius: 999px;
  display: inline-block;
  width: auto;
  max-width: none;
  position: relative;
  left: 50%;
  transform: translateX(-50%);
}

/* ── Risk reminder ──────────────────────────────────────────────────── */
.tradentry-risk-reminder {
  margin-top: 8px;
  padding: 8px 10px;
  font-size: 11px;
  color: var(--tc-warning);
  background: rgba(245,158,11,.10);
  border-left: 3px solid var(--tc-warning);
  border-radius: 4px;
  font-style: italic;
}

/* ── Loading dots ────────────────────────────────────────────────────── */
.tradentry-loading .tradentry-msg__body::after {
  content: '';
  display: inline-block;
  width: 4px; height: 4px;
  margin-left: 6px;
  background: var(--tc-text-muted);
  border-radius: 50%;
  animation: tc-dots 1.2s infinite;
}
@keyframes tc-dots {
  0%, 80%, 100% { opacity: .2; }
  40%           { opacity: 1; }
}

/* ── Disclaimer ──────────────────────────────────────────────────────── */
.tradentry-disclaimer {
  margin: 0;
  padding: 8px 14px;
  font-size: 10.5px;
  text-align: center;
  color: var(--tc-text-muted);
  background: rgba(255,255,255,.02);
  border-top: 1px solid var(--tc-border-soft);
}

/* ── Input row ──────────────────────────────────────────────────────── */
.tradentry-input-row {
  display: flex;
  gap: 8px;
  padding: 12px;
  background: var(--tc-bg-header);
  border-top: 1px solid var(--tc-border-soft);
}
.tradentry-input {
  flex: 1;
  resize: none;
  border: 1px solid var(--tc-border);
  background: var(--tc-bg-input);
  color: var(--tc-text);
  border-radius: var(--tc-radius-sm);
  padding: 11px 14px;
  font-family: var(--tc-font);
  font-size: 13px;
  line-height: 1.4;
  outline: none;
  transition: border-color .2s, background .2s, box-shadow .2s;
}
.tradentry-input::placeholder { color: var(--tc-text-muted); }
.tradentry-input:focus {
  border-color: var(--tc-accent);
  background: rgba(28,46,72,.85);
  box-shadow: 0 0 0 3px rgba(0,229,255,.12), 0 0 14px rgba(0,229,255,.18);
}
.tradentry-input:disabled { opacity: .5; cursor: not-allowed; }

.tradentry-send {
  background: var(--tc-accent-grad);
  color: var(--tc-text-on-accent);
  border: none;
  border-radius: var(--tc-radius-sm);
  padding: 0 18px;
  font-family: var(--tc-font);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .02em;
  cursor: pointer;
  transition: transform .15s cubic-bezier(.34,1.56,.64,1), box-shadow .15s, filter .15s;
  box-shadow: 0 4px 12px rgba(0,229,255,.32), 0 1px 3px rgba(0,0,0,.25);
}
.tradentry-send:hover  { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(0,229,255,.5), 0 2px 6px rgba(0,0,0,.3); filter: brightness(1.08); }
.tradentry-send:active { transform: translateY(0); }
.tradentry-send:disabled { opacity: .5; cursor: not-allowed; transform: none; filter: none; }

/* ── Guided menu (categories + questions) ───────────────────────────── */
.tradentry-menu {
  margin: 8px 0 14px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(0,229,255,.06) 0%, rgba(92,242,255,.04) 100%);
  border: 1px solid var(--tc-border);
  border-radius: var(--tc-radius);
  animation: tc-msg-in .35s ease-out;
}
.tradentry-menu__lbl {
  font-family: var(--tc-font-heading);
  font-size: 10.5px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: rgba(142, 163, 194, .85);
  margin: 0 0 12px;
  font-weight: 600;
}
.tradentry-menu__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.tradentry-menu__list { display: flex; flex-direction: column; gap: 7px; }

.tradentry-chip,
.tradentry-q,
.tradentry-back {
  display: block;
  width: 100%;
  text-align: left;
  background: rgba(255,255,255,.03);
  color: var(--tc-text);
  border: 1px solid var(--tc-border);
  border-radius: var(--tc-radius-sm);
  padding: 11px 13px;
  font-family: var(--tc-font);
  font-size: 12.5px;
  font-weight: 500;
  cursor: pointer;
  transition: all .2s cubic-bezier(.34,1.56,.64,1);
  line-height: 1.4;
  position: relative;
  overflow: hidden;
}
.tradentry-q::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--tc-accent-grad);
  transform: scaleY(0);
  transform-origin: center;
  transition: transform .2s;
}
.tradentry-chip {
  text-align: center;
  font-weight: 700;
  color: var(--tc-text-white);
  background: rgba(0,229,255,.08);
}
.tradentry-chip:hover {
  background: var(--tc-accent-grad);
  color: var(--tc-text-on-accent);
  border-color: transparent;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,229,255,.4);
}
.tradentry-q:hover {
  background: rgba(0,229,255,.10);
  border-color: var(--tc-accent);
  transform: translateX(3px);
  box-shadow: 0 4px 14px rgba(0,229,255,.18);
  color: var(--tc-text-white);
}
.tradentry-q:hover::before { transform: scaleY(1); }
.tradentry-back {
  width: auto;
  background: transparent;
  border: none;
  color: var(--tc-accent-hover);
  font-size: 11px;
  margin-bottom: 10px;
  padding: 4px 8px 4px 0;
}
.tradentry-back:hover { color: var(--tc-text-white); transform: none; }

/* ── "Talk to an Assistant" CTA ─────────────────────────────────────── */
.tradentry-handoff-cta {
  margin: 14px 0 6px;
  text-align: center;
  animation: tc-msg-in .3s ease-out;
}
.tradentry-handoff-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--tc-accent-grad);
  color: var(--tc-text-white);
  border: none;
  border-radius: 999px;
  padding: 10px 18px;
  font-family: var(--tc-font);
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  transition: transform .15s, box-shadow .15s;
  box-shadow: 0 4px 14px rgba(139,92,246,.35);
}
.tradentry-handoff-btn::before { content: '👋'; }
.tradentry-handoff-btn:hover  { transform: translateY(-2px); box-shadow: 0 8px 20px rgba(139,92,246,.5); }

/* ── Mobile ─────────────────────────────────────────────────────────── */
@media ( max-width: 480px ) {
  .tradentry-panel {
    width: calc(100vw - 16px);
    right: 8px;
    bottom: 88px;
    height: calc(100vh - 110px);
  }
  .tradentry-fab {
    bottom: 16px;
    right: 16px;
    width: 56px; height: 56px;
  }
}

/* ── v2.1 — Inline language picker (in chat thread) ─────────────────── */
.tradentry-lang-card--inline {
  margin: 6px 0 14px;
  padding: 12px;
  background: linear-gradient(135deg, rgba(59,130,246,.08) 0%, rgba(139,92,246,.08) 100%);
  border: 1px solid var(--tc-border-soft);
  border-radius: var(--tc-radius-sm);
}

/* ── v2.1 — Country picker grid ─────────────────────────────────────── */
.tradentry-country-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px;
  margin-top: 6px;
}
.tradentry-country-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 10px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--tc-border-soft);
  border-radius: var(--tc-radius-sm);
  color: var(--tc-text);
  font-family: var(--tc-font);
  font-size: 12px;
  cursor: pointer;
  transition: background .12s, border-color .12s, transform .1s;
  text-align: left;
}
.tradentry-country-chip:hover {
  background: rgba(59,130,246,.10);
  border-color: var(--tc-accent);
  transform: translateX(2px);
}
.tradentry-country-chip__flag { font-size: 16px; }
.tradentry-country-chip__name { flex: 1; }

/* ── v2.1.1 — Hard close lock (red) ─────────────────────────────────── */
.tradentry-status--closed {
  background: linear-gradient(90deg, rgba(239,68,68,.18) 0%, rgba(239,68,68,.06) 100%) !important;
  color: var(--tc-danger) !important;
  border-bottom: 1px solid rgba(239,68,68,.3) !important;
}
.tradentry-status--closed::before {
  background: var(--tc-danger) !important;
  box-shadow: 0 0 6px var(--tc-danger);
  animation: none !important;
}
.tradentry-panel--closed .tradentry-messages {
  filter: grayscale(.4) brightness(.85);
  pointer-events: none; /* visitor cannot click main-menu / pickers anymore */
}
.tradentry-restart-cta {
  text-align: center;
  padding: 14px 12px;
  background: var(--tc-bg-header);
  border-top: 1px solid rgba(239,68,68,.2);
  animation: tc-fade-in .25s ease;
}
.tradentry-restart-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--tc-accent-grad);
  color: var(--tc-text-white);
  border: none;
  border-radius: 999px;
  padding: 10px 18px;
  font-family: var(--tc-font);
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(59,130,246,.35);
  transition: transform .12s, box-shadow .12s;
}
.tradentry-restart-btn { color: var(--tc-text-on-accent); box-shadow: 0 6px 18px rgba(0,229,255,.4); }
.tradentry-restart-btn:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(0,229,255,.5); filter: brightness(1.08); }

/* ── v2.1 — Globe icon (header) ─────────────────────────────────────── */
.tradentry-globe {
  background: transparent;
  border: 1px solid var(--tc-border-soft);
  color: var(--tc-text);
  font-size: 14px;
  width: 32px; height: 32px;
  border-radius: 50%;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  margin-right: 4px;
  transition: background .12s, border-color .12s;
}
.tradentry-globe:hover { background: rgba(255,255,255,.08); border-color: var(--tc-accent); }

/* ── v2.1 — Always-visible action bar ───────────────────────────────── */
.tradentry-actionbar {
  display: flex;
  gap: 6px;
  padding: 8px 10px;
  background: var(--tc-bg-header);
  border-top: 1px solid var(--tc-border-soft);
}
.tradentry-action {
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 7px 8px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--tc-border-soft);
  border-radius: var(--tc-radius-sm);
  color: var(--tc-text);
  font-family: var(--tc-font);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  transition: transform .1s, background .12s, border-color .12s;
}
.tradentry-action:hover {
  transform: translateY(-1px);
  border-color: var(--tc-accent);
  background: rgba(0,229,255,.10);
  color: var(--tc-text-white);
  box-shadow: 0 4px 12px rgba(0,229,255,.2);
}
.tradentry-action--agent { color: var(--tc-success); border-color: rgba(34,230,154,.35); }
.tradentry-action--agent:hover {
  background: rgba(34,230,154,.12);
  border-color: var(--tc-success);
  box-shadow: 0 4px 12px rgba(34,230,154,.25);
}
.tradentry-action--end { color: var(--tc-text-muted); border-color: var(--tc-border); }
.tradentry-action--end:hover {
  background: rgba(255,255,255,.05);
  border-color: var(--tc-text-muted);
  color: var(--tc-text-white);
  box-shadow: 0 4px 12px rgba(0,0,0,.2);
}

/* ── v2.1 — Main menu CTA after each answer ────────────────────────── */
.tradentry-mainmenu-cta {
  margin: 10px 0 4px;
  text-align: center;
  animation: tc-msg-in .3s ease-out;
}
.tradentry-mainmenu-btn {
  display: inline-block;
  padding: 7px 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid var(--tc-border-soft);
  border-radius: 999px;
  color: var(--tc-accent-hover);
  font-family: var(--tc-font);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  transition: background .12s, border-color .12s;
}
.tradentry-mainmenu-btn:hover {
  background: rgba(59,130,246,.12);
  border-color: var(--tc-accent);
  color: var(--tc-text-white);
}

/* ── v2.0 — Language picker ─────────────────────────────────────────── */
.tradentry-lang-card {
  margin: 12px 0;
  padding: 22px 18px 18px;
  background: linear-gradient(135deg, rgba(59,130,246,.08) 0%, rgba(139,92,246,.08) 100%);
  border: 1px solid var(--tc-border-soft);
  border-radius: var(--tc-radius);
  text-align: center;
  animation: tc-msg-in .3s ease-out;
}
.tradentry-lang-card__title {
  margin: 0 0 6px; font-size: 15px; color: var(--tc-text-white); font-weight: 700;
}
.tradentry-lang-card__sub {
  margin: 0 0 16px; font-size: 12px; color: var(--tc-text-muted);
}
.tradentry-lang-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 8px;
}
.tradentry-lang-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  background: rgba(255,255,255,.03);
  border: 1px solid var(--tc-border);
  border-radius: var(--tc-radius-sm);
  padding: 14px 10px;
  color: var(--tc-text);
  font-family: var(--tc-font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all .25s cubic-bezier(.34,1.56,.64,1);
}
.tradentry-lang-btn:hover {
  transform: translateY(-3px);
  background: var(--tc-accent-grad);
  border-color: transparent;
  color: var(--tc-text-on-accent);
  box-shadow: 0 10px 24px rgba(0,229,255,.4), 0 2px 6px rgba(0,0,0,.2);
  font-weight: 700;
}
.tradentry-lang-btn__flag {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .04em;
  background: rgba(0,229,255,.18);
  border: 1px solid rgba(0,229,255,.35);
  color: var(--tc-accent);
  padding: 3px 7px;
  border-radius: 6px;
  text-transform: uppercase;
  transition: all .2s;
}
.tradentry-lang-btn:hover .tradentry-lang-btn__flag {
  background: rgba(255,255,255,.25);
  border-color: rgba(255,255,255,.5);
  color: var(--tc-text-on-accent);
}

/* ── v2.0 — Consent card ────────────────────────────────────────────── */
.tradentry-consent-card {
  margin: 12px 0;
  padding: 18px;
  background: linear-gradient(135deg, rgba(245,158,11,.10) 0%, rgba(245,158,11,.04) 100%);
  border: 1px solid rgba(245,158,11,.25);
  border-radius: var(--tc-radius);
  animation: tc-msg-in .3s ease-out;
}
.tradentry-consent-card__text {
  margin: 0 0 14px; font-size: 12.5px; line-height: 1.55; color: var(--tc-text);
}
.tradentry-consent-card__btn {
  display: block; width: 100%;
  background: var(--tc-accent-grad);
  color: var(--tc-text-white);
  border: none;
  border-radius: var(--tc-radius-sm);
  padding: 11px 14px;
  font-family: var(--tc-font);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: transform .12s, box-shadow .12s;
  box-shadow: 0 4px 12px rgba(59,130,246,.35);
}
.tradentry-consent-card__btn:hover { transform: translateY(-1px); box-shadow: 0 6px 16px rgba(59,130,246,.5); }

/* ── v2.0 — Free-text hint under quick topics ──────────────────────── */
.tradentry-menu__hint {
  margin: 10px 0 0;
  font-size: 11px;
  color: var(--tc-text-muted);
  text-align: center;
  font-style: italic;
}

/* ── v2.4 — Typing indicator (animated dots) ────────────────────────── */
.tradentry-typing__dots {
  display: inline-flex !important;
  align-items: center;
  gap: 5px;
  padding: 14px 16px !important;
  min-height: 22px;
}
.tradentry-typing__dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--tc-accent);
  box-shadow: 0 0 8px rgba(0,229,255,.5);
  animation: tc-typing-bounce 1.2s cubic-bezier(.4,0,.6,1) infinite;
}
.tradentry-typing__dot:nth-child(2) { animation-delay: .15s; }
.tradentry-typing__dot:nth-child(3) { animation-delay: .30s; }
@keyframes tc-typing-bounce {
  0%, 60%, 100% { transform: translateY(0);   opacity: .6; }
  30%           { transform: translateY(-5px); opacity: 1; }
}

/* ── v2.4 — Feedback (helpful?) ─────────────────────────────────────── */
.tradentry-feedback {
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: var(--tc-text-muted);
}
.tradentry-feedback__lbl { letter-spacing: .02em; }
.tradentry-feedback__btn {
  border: 1px solid var(--tc-border);
  background: rgba(255,255,255,.03);
  color: var(--tc-text-muted);
  cursor: pointer;
  width: 26px; height: 26px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
  font-size: 13px;
  padding: 0;
}
.tradentry-feedback__btn:hover {
  border-color: var(--tc-accent);
  background: rgba(0,229,255,.1);
  color: var(--tc-text-white);
  transform: translateY(-1px);
}
.tradentry-feedback__btn.is-active {
  background: var(--tc-accent-grad);
  color: var(--tc-text-on-accent);
  border-color: transparent;
  box-shadow: 0 0 12px rgba(0,229,255,.35);
}
.tradentry-feedback.is-done .tradentry-feedback__btn:not(.is-active) { display: none; }
.tradentry-feedback.is-done .tradentry-feedback__lbl { color: var(--tc-success); }

/* ── v2.4 — Follow-up suggestions ───────────────────────────────────── */
.tradentry-followups {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.tradentry-followups__btn {
  background: rgba(0,229,255,.06);
  border: 1px solid rgba(0,229,255,.25);
  color: var(--tc-accent);
  border-radius: 999px;
  padding: 6px 12px;
  font-family: var(--tc-font);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  transition: all .2s;
  white-space: nowrap;
}
.tradentry-followups__btn:hover {
  background: var(--tc-accent-grad);
  color: var(--tc-text-on-accent);
  border-color: transparent;
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0,229,255,.3);
}

/* ── v2.4 — Proactive bubble notification ───────────────────────────── */
.tradentry-pbubble {
  position: fixed;
  bottom: 110px;
  right: 28px;
  z-index: calc(var(--tc-z) - 1);
  background: var(--tc-bg-panel);
  backdrop-filter: blur(20px);
  border: 1px solid var(--tc-border);
  border-radius: 14px;
  padding: 12px 16px;
  color: var(--tc-text);
  font-family: var(--tc-font);
  font-size: 13px;
  font-weight: 500;
  box-shadow: 0 12px 30px rgba(0,0,0,.5), 0 4px 14px rgba(0,229,255,.2), 0 0 0 1px rgba(77,214,232,.2);
  cursor: pointer;
  max-width: 240px;
  animation: tc-pbubble-in .4s cubic-bezier(.34,1.56,.64,1);
  display: flex;
  align-items: center;
  gap: 8px;
}
.tradentry-pbubble::after {
  content: '';
  position: absolute;
  bottom: -6px; right: 30px;
  width: 12px; height: 12px;
  background: var(--tc-bg-panel);
  border-right: 1px solid var(--tc-border);
  border-bottom: 1px solid var(--tc-border);
  transform: rotate(45deg);
}
.tradentry-pbubble__close {
  background: transparent;
  border: none;
  color: var(--tc-text-muted);
  cursor: pointer;
  font-size: 16px;
  padding: 0 0 0 4px;
  line-height: 1;
}
.tradentry-pbubble__close:hover { color: var(--tc-text-white); }
@keyframes tc-pbubble-in {
  from { opacity: 0; transform: translateY(10px) scale(.92); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ── Mobile + tablet responsiveness ─────────────────────────────────── */

/* Tablet (≤768px) — panel still windowed but adapted */
@media (max-width: 768px) and (min-width: 481px) {
  .tradentry-panel {
    width: min(420px, calc(100vw - 32px));
    height: min(640px, calc(100vh - 140px));
  }
  .tradentry-fab { width: 64px; height: 64px; bottom: 20px; right: 20px; }
}

/* Phone (≤480px) — panel goes full-screen */
@media (max-width: 480px) {
  .tradentry-fab {
    bottom: max(16px, env(safe-area-inset-bottom));
    right:  max(16px, env(safe-area-inset-right));
    width:  60px;
    height: 60px;
  }

  .tradentry-panel {
    /* Fullscreen, ignore safe-area on the sides for max width, pad inner content */
    bottom: 0;
    right: 0;
    left: 0;
    top: 0;
    width: 100%;
    height: 100dvh;
    max-height: 100dvh;
    max-width: 100vw;
    border-radius: 0;
    border: none;
    /* Subtle slide-up only — no scale flicker */
    animation: tc-slide-up-mobile .28s cubic-bezier(.34,1.56,.64,1);
  }

  /* Header — bigger touch targets, respect notch */
  .tradentry-header {
    padding: 14px 16px;
    padding-top: max(14px, env(safe-area-inset-top));
    padding-left:  max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }
  .tradentry-header__logo { width: 38px; height: 38px; }
  .tradentry-title { font-size: 17px; }
  .tradentry-close,
  .tradentry-globe {
    width: 44px; height: 44px;  /* Apple HIG minimum */
    font-size: 18px;
  }

  /* Messages list — keep readable padding, account for safe areas */
  .tradentry-messages {
    padding: 16px;
    padding-left:  max(16px, env(safe-area-inset-left));
    padding-right: max(16px, env(safe-area-inset-right));
  }
  .tradentry-msg { max-width: 92%; }
  .tradentry-msg__body { font-size: 14px; padding: 12px 14px; }

  /* Input row — prevent iOS zoom, larger send button */
  .tradentry-input-row {
    padding: 10px 12px;
    padding-bottom: max(10px, env(safe-area-inset-bottom));
    gap: 8px;
  }
  .tradentry-input {
    font-size: 16px;          /* prevents iOS Safari auto-zoom */
    padding: 12px 14px;
    min-height: 44px;
  }
  .tradentry-send {
    min-width: 64px;
    min-height: 44px;
    font-size: 14px;
    padding: 0 16px;
  }

  /* Action bar — wrap nicely and keep touch-friendly height */
  .tradentry-actionbar {
    flex-wrap: wrap;
    padding: 8px 10px;
    padding-bottom: max(8px, env(safe-area-inset-bottom));
    gap: 6px;
  }
  .tradentry-action {
    flex: 1 1 calc(50% - 6px);
    font-size: 11.5px;
    padding: 10px 8px;
    min-height: 40px;
  }

  /* Topics + lang picker — bigger tap targets */
  .tradentry-q,
  .tradentry-chip,
  .tradentry-followups__btn {
    padding: 13px 14px;
    font-size: 13.5px;
  }
  .tradentry-followups__btn { padding: 9px 14px; }
  .tradentry-lang-btn {
    padding: 16px 10px;
    font-size: 14px;
  }
  .tradentry-menu__grid { grid-template-columns: 1fr; }

  /* Disable FAB pulse halo on small screens (battery + perf) */
  .tradentry-fab { animation: none; }
  .tradentry-fab::before { animation: none; opacity: .4; }

  /* Proactive bubble — left of FAB to avoid overlap, fit one line */
  .tradentry-pbubble {
    bottom: max(86px, calc(env(safe-area-inset-bottom) + 70px));
    right:  max(16px, env(safe-area-inset-right));
    max-width: calc(100vw - 32px);
    font-size: 13px;
    padding: 11px 14px;
  }

  /* Feedback row — wrap if cramped */
  .tradentry-feedback { flex-wrap: wrap; }
  .tradentry-feedback__btn { width: 32px; height: 32px; }
}

/* Reduce motion — respect user OS setting */
@media (prefers-reduced-motion: reduce) {
  .tradentry-fab,
  .tradentry-fab::before,
  .tradentry-typing__dot,
  .tradentry-panel,
  .tradentry-msg,
  .tradentry-pbubble {
    animation: none !important;
  }
  .tradentry-fab:hover,
  .tradentry-send:hover,
  .tradentry-q:hover,
  .tradentry-lang-btn:hover { transform: none !important; }
}

@keyframes tc-slide-up-mobile {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Tiny screens (≤360px) — switch lang picker to single column for breathing room */
@media (max-width: 360px) {
  .tradentry-lang-grid { grid-template-columns: 1fr; }
}

/* ── v2.0 — Source link under bot answer ────────────────────────────── */
.tradentry-source {
  margin-top: 6px;
  text-align: right;
}
.tradentry-source a {
  color: var(--tc-accent);
  text-decoration: none;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .02em;
  border: 1px solid rgba(0,229,255,.35);
  background: rgba(0,229,255,.08);
  padding: 4px 11px;
  border-radius: 999px;
  transition: all .2s;
  box-shadow: 0 0 0 0 rgba(0,229,255,0);
}
.tradentry-source a:hover {
  background: var(--tc-accent-grad);
  color: var(--tc-text-on-accent);
  border-color: transparent;
  box-shadow: 0 4px 14px rgba(0,229,255,.4);
  transform: translateY(-1px);
}

/* ── v2.0 — RTL support for Arabic ──────────────────────────────────── */
.tradentry-rtl { direction: rtl; }
.tradentry-rtl .tradentry-msg--user { margin-right: auto; margin-left: 0; text-align: left; }
.tradentry-rtl .tradentry-msg--user .tradentry-msg__body { text-align: right; }
.tradentry-rtl .tradentry-msg--assistant .tradentry-msg__body,
.tradentry-rtl .tradentry-msg--agent .tradentry-msg__body { text-align: right; }
.tradentry-rtl .tradentry-source { text-align: left; }
.tradentry-rtl .tradentry-q,
.tradentry-rtl .tradentry-chip { text-align: right; }

/* ── Admin status colors (unchanged) ────────────────────────────────── */


/* ============================================================
   FLIPO v2.5 — Premium Tradentry alignment polish
   Subtle layered depth, refined header, cleaner input row.
   ============================================================ */
.tradentry-fab{
  background:
    radial-gradient(circle at 30% 25%, rgba(255,255,255,.32), transparent 55%),
    linear-gradient(135deg,#00e5ff 0%,#4dd6e8 55%,#7df1ff 100%);
  border:1px solid rgba(255,255,255,.18);
}
.tradentry-fab::after{
  inset:1px;
  border:1px solid rgba(255,255,255,.18);
  background:
    radial-gradient(circle at 50% 0%, rgba(255,255,255,.18), transparent 60%);
}
.tradentry-panel{
  background:
    radial-gradient(ellipse 120% 80% at 100% 0%, rgba(0,229,255,.08), transparent 55%),
    radial-gradient(ellipse 100% 60% at 0% 100%, rgba(125,241,255,.05), transparent 55%),
    linear-gradient(180deg, rgba(10,24,40,.94) 0%, rgba(6,13,28,.96) 100%);
  border:1px solid rgba(77,214,232,.18);
  box-shadow:
    0 30px 80px rgba(0,0,0,.65),
    0 12px 32px rgba(0,229,255,.10),
    0 0 0 1px rgba(77,214,232,.10),
    inset 0 1px 0 rgba(255,255,255,.04);
}
.tradentry-panel::before{
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(0,229,255,.65), transparent);
  filter:none;
}
.tradentry-header{
  background:
    linear-gradient(180deg, rgba(13,28,50,.92) 0%, rgba(10,22,40,.78) 100%);
  padding:14px 18px;
}
.tradentry-header__logo{
  border-radius:12px;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,229,255,.32), transparent 60%),
    linear-gradient(135deg, rgba(0,229,255,.18), rgba(125,241,255,.04));
  box-shadow:
    0 0 18px rgba(0,229,255,.28),
    inset 0 1px 0 rgba(255,255,255,.1);
}
.tradentry-title{
  font-size:15px;
  letter-spacing:.04em;
}
.tradentry-title::before{
  width:7px;height:7px;
  box-shadow:0 0 0 3px rgba(34,230,154,.18), 0 0 8px var(--tc-success);
}
.tradentry-input{
  background:
    linear-gradient(180deg, rgba(19,36,61,.7), rgba(15,30,52,.55));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.03);
}
.tradentry-input:focus{
  background:
    linear-gradient(180deg, rgba(28,46,72,.85), rgba(19,36,61,.7));
  box-shadow:
    0 0 0 3px rgba(0,229,255,.14),
    0 0 18px rgba(0,229,255,.18),
    inset 0 1px 0 rgba(255,255,255,.05);
}
.tradentry-send{
  background:
    linear-gradient(135deg,#00e5ff 0%,#4dd6e8 55%,#7df1ff 100%);
  box-shadow:
    0 6px 16px rgba(0,229,255,.38),
    0 1px 2px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.3);
  min-width:64px;
}
.tradentry-msg--user .tradentry-msg__body{
  background:
    linear-gradient(135deg,#00e5ff 0%,#4dd6e8 55%,#7df1ff 100%);
  box-shadow:
    0 8px 22px rgba(0,229,255,.32),
    0 2px 6px rgba(0,229,255,.16),
    inset 0 1px 0 rgba(255,255,255,.22);
}
.tradentry-msg--assistant .tradentry-msg__body{
  background:
    linear-gradient(180deg, rgba(19,36,61,.92) 0%, rgba(13,28,50,.85) 100%);
  border:1px solid rgba(77,214,232,.18);
  box-shadow:
    0 4px 16px rgba(0,0,0,.3),
    inset 0 1px 0 rgba(255,255,255,.04);
}
.tradentry-q{
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
}
.tradentry-q:hover{
  background:
    linear-gradient(180deg, rgba(0,229,255,.14), rgba(0,229,255,.06));
}
.tradentry-actionbar{
  background:
    linear-gradient(180deg, rgba(13,28,50,.78) 0%, rgba(10,22,40,.92) 100%);
}
.tradentry-action{
  background:
    linear-gradient(180deg, rgba(255,255,255,.055), rgba(255,255,255,.02));
}
.tradentry-pbubble{
  background:
    linear-gradient(180deg, rgba(13,28,50,.95) 0%, rgba(10,22,40,.95) 100%);
  border:1px solid rgba(77,214,232,.22);
  box-shadow:
    0 16px 40px rgba(0,0,0,.55),
    0 6px 18px rgba(0,229,255,.20),
    0 0 0 1px rgba(77,214,232,.16);
}
