.tabora-support-widget {
  --navy:#0F1E34;
  --muted:#6B778C;
  --line:#DED8CA;
  --bg:#F6F2E8;
  --orange:#D4A444;
  font-family: Inter, Arial, Helvetica, sans-serif;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 18px 50px rgba(15,30,52,.10);
  overflow:hidden;
  max-width:720px;
}
.tabora-support-header { padding:20px 22px; background:linear-gradient(180deg, #0F1E34, #081426); color:#fff; }
.tabora-support-header strong { display:block; font-size:20px; }
.tabora-support-header span { display:block; color:rgba(255,255,255,.74); margin-top:4px; font-size:14px; }
.tabora-support-messages { padding:18px; display:grid; gap:12px; max-height:420px; overflow:auto; background:#FAF7F0; }
.tabora-support-message { padding:14px 16px; border-radius:18px; line-height:1.5; font-size:15px; }
.tabora-support-message.bot { background:#fff; color:var(--navy); border:1px solid var(--line); }
.tabora-support-message.user { background:#F0F3F7; color:var(--navy); justify-self:end; max-width:85%; }
.tabora-support-form { display:flex; gap:10px; padding:14px; border-top:1px solid var(--line); }
.tabora-support-input { flex:1; border:1px solid var(--line); border-radius:14px; padding:14px; font:inherit; }
.tabora-support-submit { border:0; border-radius:14px; padding:0 20px; background:linear-gradient(180deg, var(--orange), #B8842D); color:#fff; font-weight:800; cursor:pointer; }
.tabora-support-note { margin:0; padding:0 18px 18px; color:var(--muted); font-size:12px; line-height:1.4; }
.tabora-support-sources { margin-top:12px; padding-top:10px; border-top:1px solid var(--line); display:grid; gap:6px; }
.tabora-support-sources strong { font-size:13px; color:var(--muted); }
.tabora-support-sources a { color:var(--navy); font-weight:700; text-decoration:none; }
.tabora-support-sources a:hover { text-decoration:underline; }
.tabora-support-warning {
  margin:0 18px 10px;
  color:#6D5122;
  background:#FBF4E7;
  border:1px solid rgba(212,164,68,.28);
  border-radius:12px;
  padding:9px 10px;
  font-size:12px;
  line-height:1.4;
  font-weight:800;
}
.tabora-support-warning[hidden] { display:none; }
.tabora-support-ticket-button {
  display:block;
  margin-top:12px;
  border:0;
  border-radius:12px;
  padding:10px 12px;
  background:linear-gradient(180deg, var(--orange), #B8842D);
  color:#fff;
  font-weight:800;
  cursor:pointer;
}
.tabora-support-ticket-button:disabled {
  cursor:not-allowed;
  opacity:.72;
}

.tabora-support-message.typing { color:#6B778C; font-weight:800; }

.tabora-support-ticket-created {
  margin-top:12px;
  padding:10px 12px;
  border-radius:12px;
  background:#EEF7F2;
  border:1px solid rgba(40,116,80,.18);
  color:#163D2B;
  font-weight:800;
  font-size:13px;
}
.support-guide-section .section-head { margin-bottom: 18px; }
.support-guide-section .tabora-support-widget { margin-top: 18px; }

.tabora-support-launcher {
  position: fixed;
  right: 22px;
  bottom: 22px;
  z-index: 50;
  font-family: Inter, Arial, Helvetica, sans-serif;
}

.tabora-support-launcher-button {
  display: grid;
  gap: 2px;
  min-width: 118px;
  border: 0;
  border-radius: 999px;
  background: linear-gradient(180deg, #0F1E34, #081426);
  color: #fff;
  padding: 12px 15px;
  box-shadow: 0 18px 44px rgba(15,30,52,.24);
  cursor: pointer;
  text-align: left;
}

.tabora-support-launcher-button strong {
  font-size: 15px;
  line-height: 1.1;
}

.tabora-support-launcher-button span {
  color: rgba(255,255,255,.72);
  font-size: 12px;
  font-weight: 750;
}

.route-home .tabora-support-launcher-button,
.route-resources .tabora-support-launcher-button,
.route-demo .tabora-support-launcher-button {
  min-width: 86px;
  text-align: center;
}

.route-home .tabora-support-launcher-button span,
.route-resources .tabora-support-launcher-button span,
.route-demo .tabora-support-launcher-button span {
  display: none;
}

.tabora-support-panel {
  position: absolute;
  right: 0;
  bottom: 74px;
  width: min(420px, calc(100vw - 32px));
  max-height: min(680px, calc(100vh - 110px));
}

.tabora-support-panel[hidden] {
  display: none;
}

.tabora-support-panel .tabora-support-messages {
  max-height: 330px;
}

@media (max-width: 640px) {
  .tabora-support-launcher {
    right: 14px;
    bottom: 14px;
  }

  .tabora-support-launcher-button {
    min-width: 132px;
    border-radius: 16px;
    padding: 11px 13px;
  }

  .tabora-support-panel {
    right: -2px;
    bottom: 66px;
  }
}

.tabora-support-faq-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.tabora-support-faq-chip {
  background: #fff;
  border: 1px solid var(--line, #dfe7f3);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 13px;
  font-weight: 700;
  color: #075de8;
  cursor: pointer;
  line-height: 1.4;
  text-align: left;
  font-family: inherit;
  transition: background 0.15s, border-color 0.15s;
}

.tabora-support-faq-chip:hover {
  background: #f0f5ff;
  border-color: #075de8;
}
