.jellyai-demo-nav {
  appearance: none;
  color: var(--text-secondary);
  cursor: pointer;
  text-align: left;
  background: transparent;
  border: none;
  border-radius: 6px;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: 100%;
  min-height: 44px;
  padding: 12px;
  font: inherit;
  font-size: 14px;
  line-height: 1.4;
  transition: background-color .15s, color .15s;
  display: flex;
  position: relative;
  box-shadow: none;
  outline: none;
}

.sidebar .nav-item,
.app-sidebar .nav-item,
aside .nav-item {
  min-height: 34px;
  padding-top: 7px;
  padding-bottom: 7px;
}

.sidebar .jellyai-demo-nav,
.app-sidebar .jellyai-demo-nav,
aside .jellyai-demo-nav {
  min-height: 34px;
  padding-top: 7px;
  padding-bottom: 7px;
}

.jellyai-demo-nav:hover {
  background-color: rgba(var(--accent-primary-rgb), .06);
  color: var(--text-primary);
}

.jellyai-demo-nav.active {
  background-color: rgba(var(--accent-primary-rgb), .12);
  color: var(--accent-primary);
}

.jellyai-demo-nav svg {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
}

.jellyai-demo-nav .nav-label {
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

.sidebar.collapsed .jellyai-demo-nav {
  justify-content: center;
  gap: 0;
  min-height: 40px;
  padding: 10px 4px;
}

.sidebar.collapsed .jellyai-demo-nav .nav-label {
  display: none;
}

.jellyai-credit-panel {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  margin: 6px 0;
  padding: 8px;
  flex-shrink: 0;
}

.jellyai-credit-compact-row {
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  display: grid;
}

.jellyai-credit-compact-row div {
  min-width: 0;
}

.jellyai-credit-compact-row span {
  color: var(--text-muted);
  font-size: 11px;
  line-height: 1.2;
  display: block;
}

.jellyai-credit-compact-row strong {
  color: var(--text-primary);
  margin-top: 3px;
  font-size: 15px;
  font-weight: 800;
  line-height: 1.15;
  display: block;
}

.jellyai-credit-head {
  border-bottom: 1px solid var(--border-light);
  gap: 4px;
  padding-bottom: 8px;
  display: grid;
}

.jellyai-credit-head span,
.jellyai-credit-balance span,
.jellyai-credit-grid span {
  color: var(--text-muted);
  font-size: 11px;
  line-height: 1.25;
}

.jellyai-credit-head strong {
  color: var(--text-primary);
  font-size: 12px;
  line-height: 1.3;
}

.jellyai-credit-balance {
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  padding: 9px 0;
  display: flex;
}

.jellyai-credit-balance strong {
  color: var(--text-primary);
  font-size: 20px;
  font-weight: 800;
  line-height: 1;
}

.jellyai-credit-grid {
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  display: grid;
}

.jellyai-credit-grid div {
  background: rgba(var(--accent-primary-rgb), .04);
  border: 1px solid var(--border-light);
  border-radius: 6px;
  padding: 7px;
  min-width: 0;
}

.jellyai-credit-grid strong {
  color: var(--text-primary);
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.2;
  display: block;
}

.jellyai-credit-model {
  color: var(--text-secondary);
  margin-top: 7px;
  padding-top: 7px;
  border-top: 1px solid var(--border-light);
  font-size: 11px;
  font-weight: 500;
  line-height: 1.25;
}

.sidebar.collapsed .jellyai-credit-panel {
  display: none;
}

.jellyai-hidden-model-entry {
  display: flex !important;
}

.jellyai-managed-model-selector {
  opacity: 1;
  pointer-events: auto;
}

.jellyai-more-toggle {
  color: var(--text-muted);
  margin-top: 2px;
  width: 100% !important;
  cursor: default !important;
}

.sidebar .nav-item:hover,
.sidebar .nav-item:focus-visible {
  background: rgba(var(--accent-primary-rgb), .1) !important;
  color: var(--text-primary) !important;
  box-shadow: inset 0 0 0 1px rgba(var(--accent-primary-rgb), .14) !important;
}

.sidebar-nav {
  overflow-y: auto !important;
  scrollbar-width: thin !important;
  padding-bottom: 10px !important;
}

.sidebar-nav::-webkit-scrollbar {
  display: block !important;
  width: 4px !important;
}

.sidebar-nav::-webkit-scrollbar-thumb {
  background: var(--border-color) !important;
  border-radius: 999px !important;
}

.jellyai-core-nav.nav-item {
  min-height: 34px !important;
}

.jellyai-more-toggle:focus,
.jellyai-more-toggle:focus-visible {
  border-color: transparent !important;
  outline: none !important;
  box-shadow: none !important;
}

.jellyai-more-toggle .jellyai-more-arrow {
  flex: none;
  width: 20px;
  text-align: center;
  transition: none;
}

.jellyai-more-toggle.open .jellyai-more-arrow {
  transform: none;
}

.jellyai-extra-nav {
  display: none !important;
}

.jellyai-original-skill-nav {
  display: none !important;
}

.jellyai-extra-nav.active,
.jellyai-extra-nav.router-link-active,
.jellyai-extra-nav.router-link-exact-active,
.jellyai-original-skill-nav.active,
.jellyai-original-skill-nav.router-link-active,
.jellyai-original-skill-nav.router-link-exact-active {
  display: none !important;
}

.jellyai-nav-more-open .jellyai-extra-nav {
  display: none !important;
}

body.jellyai-nav-more-open .jellyai-extra-nav {
  display: none !important;
}

.jellyai-more-menu {
  display: flex !important;
  flex-direction: column;
  gap: 2px;
  width: 100%;
  max-height: none;
  margin: 2px 0 8px;
  padding: 0;
  overflow-y: visible !important;
  overflow-x: hidden !important;
  position: static !important;
  z-index: auto !important;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  box-sizing: border-box;
  pointer-events: auto !important;
}

.jellyai-floating-more-menu {
  display: none !important;
}

.jellyai-floating-more-menu.open {
  display: none !important;
}

.jellyai-nav-more-open .jellyai-more-menu,
body.jellyai-nav-more-open .jellyai-more-menu {
  display: flex !important;
}

.jellyai-more-menu-item {
  appearance: none !important;
  display: flex !important;
  visibility: visible !important;
  opacity: 1 !important;
  position: relative !important;
  z-index: 2 !important;
  width: 100% !important;
  min-height: 34px !important;
  color: var(--text-secondary);
  background: transparent !important;
  border: 0 !important;
  border-radius: 6px !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px !important;
  margin: 0 !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  text-decoration: none !important;
  text-align: left !important;
  padding: 7px 12px !important;
  font: inherit !important;
  font-size: 14px !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
  outline: none !important;
  box-sizing: border-box !important;
  transition: background-color .15s, color .15s;
}

.jellyai-more-menu-item:hover,
.jellyai-more-menu-item:focus-visible,
.jellyai-more-menu-item.active {
  color: var(--text-primary);
  background: rgba(var(--accent-primary-rgb), .1) !important;
  box-shadow: inset 0 0 0 1px rgba(var(--accent-primary-rgb), .14) !important;
}

.jellyai-more-menu-item:active {
  background: rgba(var(--accent-primary-rgb), .1) !important;
}

.jellyai-more-menu-item.active {
  background: rgba(var(--accent-primary-rgb), .12) !important;
  color: var(--accent-primary);
  font-weight: 600;
}

.jellyai-more-menu-item .nav-label {
  display: block !important;
  min-width: 0;
  overflow: hidden !important;
  text-overflow: ellipsis;
  white-space: nowrap !important;
}

.jellyai-more-menu-item svg {
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
}

.jellyai-more-menu-dot {
  display: none !important;
}

.jellyai-demo-hidden {
  display: none !important;
}

.jellyai-legacy-section-hidden {
  display: none !important;
}

.jellyai-chat-credit-bar {
  background: var(--bg-card);
  border-bottom: 1px solid var(--border-color);
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 12px 20px;
  display: flex;
  flex-shrink: 0;
}

.jellyai-chat-credit-main {
  min-width: 0;
}

.jellyai-chat-credit-title {
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 700;
  line-height: 1.3;
}

.jellyai-chat-credit-desc {
  color: var(--text-secondary);
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.45;
}

.jellyai-chat-credit-desc strong {
  color: var(--accent-primary);
}

.jellyai-chat-credit-side {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  display: flex;
}

.jellyai-chat-credit-side span {
  color: var(--text-secondary);
  background: rgba(var(--accent-primary-rgb), .05);
  border: 1px solid var(--border-light);
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 12px;
  white-space: nowrap;
}

.jellyai-chat-credit-side strong {
  color: var(--text-primary);
}

.jellyai-credit-test-btn {
  appearance: none;
  color: var(--text-secondary);
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 999px;
  cursor: pointer;
  padding: 3px 9px;
  font: inherit;
  font-size: 12px;
}

.jellyai-credit-test-btn:hover {
  color: var(--text-primary);
  border-color: var(--accent-muted);
}

.jellyai-credit-test-btn.is-low {
  color: var(--error);
  border-color: rgba(var(--error-rgb), .35);
  background: rgba(var(--error-rgb), .08);
}

.jellyai-credit-toast {
  z-index: 10000;
  color: var(--text-on-overlay);
  background: rgba(20, 20, 20, .92);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 8px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, .24);
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 600;
  opacity: 0;
  transform: translateY(8px);
  transition: opacity .18s, transform .18s;
  position: fixed;
  right: 24px;
  bottom: 24px;
}

.jellyai-credit-toast.show {
  opacity: 1;
  transform: translateY(0);
}

.jellyai-credit-toast.error {
  background: rgba(var(--error-rgb), .96);
}

.jellyai-composer-lift {
  z-index: 50 !important;
  background: var(--bg-primary) !important;
  border-top: 1px solid var(--border-color) !important;
  box-shadow: 0 -12px 28px rgba(0, 0, 0, .06) !important;
  margin-bottom: 22px !important;
  transform: translateY(-22px);
}

.jellyai-composer-lift textarea,
.jellyai-composer-lift [contenteditable="true"],
.jellyai-composer-lift [role="textbox"] {
  min-height: 42px !important;
  max-height: 140px !important;
}

.jellyai-composer-lift button {
  flex-shrink: 0;
}

body .chat-input-area {
  z-index: 60 !important;
  background: var(--bg-primary) !important;
  border-top: 1px solid var(--border-color) !important;
  box-shadow: 0 -12px 28px rgba(0, 0, 0, .06) !important;
  padding-bottom: 20px !important;
  position: relative !important;
  transform: translateY(-58px) !important;
}

body .message-list {
  padding-bottom: 92px !important;
}

body .chat-input-area .input-wrapper {
  min-height: 50px !important;
}

.jellyai-credit-toast.success {
  background: rgba(var(--success-rgb), .96);
}

.jellyai-demo-page {
  min-height: 100%;
  background: var(--bg-primary);
  color: var(--text-primary);
}

.jellyai-demo-header {
  border-bottom: 1px solid var(--border-color);
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding: 21px 20px;
  display: flex;
}

.jellyai-demo-title {
  color: var(--text-primary);
  font-size: 16px;
  font-weight: 600;
}

.jellyai-demo-subtitle {
  color: var(--text-muted);
  margin-top: 2px;
  font-size: 12px;
}

.jellyai-demo-status {
  color: var(--success);
  border: 1px solid rgba(var(--success-rgb), .24);
  background: rgba(var(--success-rgb), .1);
  border-radius: 999px;
  flex: none;
  padding: 3px 10px;
  font-size: 12px;
  font-weight: 600;
}

.jellyai-demo-header-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  display: flex;
}

.jellyai-demo-action-btn,
.jellyai-demo-inline-btn {
  appearance: none;
  cursor: pointer;
  border-radius: 6px;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 6px 12px;
  font: inherit;
  font-size: 12px;
  font-weight: 600;
  transition: background-color .15s, border-color .15s, color .15s;
  display: inline-flex;
}

.jellyai-demo-action-btn {
  color: var(--text-on-accent);
  background: var(--accent-primary);
  border: 1px solid var(--accent-primary);
}

.jellyai-demo-action-btn:hover {
  background: var(--accent-hover);
  border-color: var(--accent-hover);
}

.jellyai-demo-inline-btn {
  color: var(--text-secondary);
  background: var(--bg-card);
  border: 1px solid var(--border-color);
}

.jellyai-demo-inline-btn:hover {
  color: var(--text-primary);
  border-color: var(--accent-muted);
}

.jellyai-demo-inline-btn.danger {
  color: var(--error);
}

.jellyai-demo-content {
  gap: 16px;
  padding: 16px 20px 28px;
  display: grid;
}

.jellyai-demo-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  display: grid;
}

.jellyai-kb-module-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  display: grid;
}

.jellyai-kb-module-card {
  appearance: none;
  color: var(--text-secondary);
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  cursor: pointer;
  text-align: left;
  min-height: 126px;
  padding: 14px;
  display: grid;
  gap: 7px;
  transition: background-color .15s, border-color .15s, color .15s, box-shadow .15s;
}

.jellyai-kb-module-card:hover {
  color: var(--text-primary);
  border-color: rgba(var(--accent-primary-rgb), .34);
  background: var(--bg-card);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-primary-rgb), .12);
}

.jellyai-kb-module-card.active {
  color: var(--text-primary);
  border-color: rgba(var(--accent-primary-rgb), .36);
  background: rgba(var(--accent-primary-rgb), .1);
  box-shadow: inset 0 0 0 1px rgba(var(--accent-primary-rgb), .14);
}

.jellyai-kb-module-modal[hidden] {
  display: none !important;
}

.jellyai-kb-module-modal {
  position: fixed;
  inset: 0;
  z-index: 1200;
  background: rgba(0, 0, 0, .38);
  align-items: center;
  justify-content: center;
  padding: 28px;
  display: flex;
}

.jellyai-kb-module-dialog {
  width: min(980px, calc(100vw - 56px));
  max-height: calc(100vh - 56px);
  overflow: auto;
  background: var(--bg-primary);
  border: 1px solid var(--border-color);
  border-radius: 10px;
  box-shadow: 0 20px 60px rgba(0, 0, 0, .28);
  padding: 18px;
}

.jellyai-kb-module-dialog .jellyai-kb-panel {
  margin-top: 12px;
}

.jellyai-kb-table-link {
  color: var(--text-primary);
  background: var(--bg-card-hover);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  margin: 4px 0 12px;
  padding: 10px 12px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  display: inline-flex;
}

.jellyai-kb-table-link[hidden] {
  display: none !important;
}

.jellyai-kb-table-link:hover {
  border-color: rgba(var(--accent-primary-rgb), .34);
}

.jellyai-kb-module-name {
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 700;
}

.jellyai-kb-module-desc,
.jellyai-kb-module-meta,
.jellyai-kb-module-card em {
  color: var(--text-muted);
  font-size: 12px;
  line-height: 1.45;
}

.jellyai-kb-module-card em {
  font-style: normal;
}

.jellyai-kb-route-list {
  gap: 8px;
  margin-top: 12px;
  display: grid;
}

.jellyai-kb-route-list div {
  background: rgba(var(--accent-primary-rgb), .04);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  gap: 4px;
  padding: 10px 12px;
  display: grid;
}

.jellyai-kb-route-list strong {
  color: var(--text-primary);
  font-size: 13px;
}

.jellyai-kb-route-list span {
  color: var(--text-muted);
  font-size: 12px;
}

.jellyai-demo-card,
.jellyai-demo-panel,
.jellyai-demo-customer {
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-radius: 8px;
}

.jellyai-demo-card {
  min-height: 92px;
  padding: 14px;
}

.jellyai-demo-config-card {
  appearance: none;
  cursor: pointer;
  text-align: left;
  width: 100%;
  display: block;
  font: inherit;
  transition: border-color .15s, background-color .15s, transform .15s;
}

.jellyai-demo-config-card:hover {
  border-color: var(--accent-muted);
  background: var(--bg-card-hover);
}

.jellyai-demo-config-card:active {
  transform: translateY(1px);
}

.jellyai-demo-card-link {
  color: var(--accent-primary);
  margin-top: 10px;
  font-size: 12px;
  font-weight: 600;
}

.jellyai-demo-card-label,
.jellyai-demo-section-label,
.jellyai-demo-mini-label {
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .3px;
  font-size: 11px;
  font-weight: 600;
}

.jellyai-demo-card-value {
  color: var(--text-primary);
  margin-top: 8px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.25;
}

.jellyai-demo-card-note {
  color: var(--text-secondary);
  margin-top: 5px;
  font-size: 12px;
  line-height: 1.45;
}

.jellyai-demo-columns {
  grid-template-columns: minmax(320px, 1fr) minmax(280px, .72fr);
  gap: 16px;
  display: grid;
}

.jellyai-demo-panel {
  min-width: 0;
  padding: 16px;
}

.jellyai-demo-panel-head {
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
  display: flex;
}

.jellyai-demo-panel-title {
  color: var(--text-primary);
  font-size: 14px;
  font-weight: 700;
}

.jellyai-demo-chip {
  color: var(--text-secondary);
  background: rgba(var(--accent-primary-rgb), .06);
  border: 1px solid var(--border-light);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 11px;
}

.jellyai-demo-flow {
  gap: 8px;
  display: grid;
}

.jellyai-demo-step {
  border: 1px solid var(--border-light);
  background: rgba(var(--accent-primary-rgb), .025);
  border-radius: 6px;
  grid-template-columns: 28px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  display: grid;
}

.jellyai-demo-step-number {
  color: var(--text-muted);
  background: var(--bg-secondary);
  border-radius: 999px;
  justify-content: center;
  align-items: center;
  width: 24px;
  height: 24px;
  font-size: 11px;
  font-weight: 700;
  display: flex;
}

.jellyai-demo-step-title {
  color: var(--text-primary);
  overflow-wrap: anywhere;
  font-size: 13px;
  font-weight: 600;
}

.jellyai-demo-step-tag {
  color: var(--text-muted);
  white-space: nowrap;
  font-size: 11px;
}

.jellyai-demo-kv {
  gap: 8px;
  display: grid;
}

.jellyai-demo-kv-row {
  border-bottom: 1px solid var(--border-light);
  justify-content: space-between;
  gap: 16px;
  padding: 8px 0;
  display: flex;
}

.jellyai-demo-kv-row:last-child {
  border-bottom: 0;
}

.jellyai-demo-kv-key {
  color: var(--text-muted);
  font-size: 12px;
}

.jellyai-demo-kv-value {
  color: var(--text-primary);
  text-align: right;
  font-size: 12px;
  font-weight: 600;
}

.jellyai-demo-message {
  background: var(--msg-user-bg);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  margin-top: 12px;
  padding: 12px;
}

.jellyai-demo-message.compact {
  margin-top: 14px;
}

.jellyai-demo-message-title {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
}

.jellyai-demo-message-body {
  color: var(--text-secondary);
  margin-top: 6px;
  font-size: 13px;
  line-height: 1.55;
}

.jellyai-demo-board {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  display: grid;
}

.jellyai-demo-lane {
  border-left: 2px solid var(--lane-color, var(--border-color));
  min-width: 0;
  padding-left: 10px;
}

.jellyai-demo-lane.high {
  --lane-color: var(--error);
}

.jellyai-demo-lane.medium {
  --lane-color: var(--warning);
}

.jellyai-demo-lane.low {
  --lane-color: var(--success);
}

.jellyai-demo-lane-head {
  color: var(--lane-color);
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  font-size: 13px;
  font-weight: 700;
  display: flex;
}

.jellyai-demo-dot {
  background: var(--lane-color);
  border-radius: 999px;
  width: 8px;
  height: 8px;
  display: inline-block;
}

.jellyai-demo-customer {
  margin-bottom: 8px;
  padding: 12px;
}

.jellyai-demo-customer-name {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
}

.jellyai-demo-customer-meta {
  color: var(--text-muted);
  margin-top: 4px;
  font-size: 11px;
}

.jellyai-demo-customer-need {
  color: var(--text-secondary);
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.45;
}

.jellyai-demo-suggestion {
  border-left: 3px solid var(--accent-primary);
  background: rgba(var(--accent-primary-rgb), .04);
  border-radius: 6px;
  margin-top: 10px;
  padding: 10px 12px;
}

.jellyai-demo-suggestion strong {
  color: var(--text-primary);
  display: block;
  font-size: 13px;
}

.jellyai-demo-suggestion span {
  color: var(--text-secondary);
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.5;
  display: block;
}

.service-dashboard {
  align-items: stretch;
}

.jellyai-service-list {
  gap: 10px;
  display: grid;
}

.jellyai-service-agent {
  border: 1px solid var(--border-light);
  background: rgba(var(--accent-primary-rgb), .025);
  border-radius: 8px;
  padding: 12px;
}

.jellyai-service-agent-head {
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  display: flex;
}

.jellyai-service-name {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
}

.jellyai-service-channel {
  color: var(--text-muted);
  margin-top: 2px;
  font-size: 11px;
}

.jellyai-service-stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
  display: grid;
}

.jellyai-service-stats span {
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border-radius: 6px;
  padding: 6px 8px;
  font-size: 12px;
  text-align: center;
}

.jellyai-kb-panel {
  overflow: hidden;
}

.jellyai-kb-layout {
  grid-template-columns: minmax(220px, .36fr) minmax(360px, 1fr);
  gap: 14px;
  display: grid;
}

.jellyai-kb-sidebar,
.jellyai-kb-main {
  min-width: 0;
}

.jellyai-kb-create {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  margin-bottom: 10px;
  display: grid;
}

.jellyai-kb-create input,
.jellyai-kb-upload input[type="file"] {
  color: var(--text-primary);
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  min-width: 0;
  min-height: 34px;
  padding: 7px 10px;
  font: inherit;
  font-size: 12px;
}

.jellyai-kb-create input:focus,
.jellyai-kb-upload input[type="file"]:focus {
  border-color: var(--accent-primary);
  outline: none;
}

.jellyai-kb-list {
  gap: 8px;
  max-height: 260px;
  padding-right: 2px;
  display: grid;
  overflow: auto;
}

.jellyai-kb-item {
  appearance: none;
  cursor: pointer;
  text-align: left;
  color: var(--text-secondary);
  background: var(--bg-secondary);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px;
  font: inherit;
  transition: background-color .15s, border-color .15s, color .15s;
  display: flex;
}

.jellyai-kb-item:hover,
.jellyai-kb-item.active {
  color: var(--text-primary);
  background: var(--bg-card-hover);
  border-color: var(--accent-muted);
}

.jellyai-kb-item strong,
.jellyai-kb-title {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
}

.jellyai-kb-item small,
.jellyai-kb-muted {
  color: var(--text-muted);
  margin-top: 3px;
  font-size: 11px;
  line-height: 1.45;
  display: block;
}

.jellyai-kb-item em {
  color: var(--text-muted);
  background: rgba(var(--accent-primary-rgb), .05);
  border: 1px solid var(--border-light);
  border-radius: 999px;
  flex: none;
  padding: 2px 7px;
  font-size: 11px;
  font-style: normal;
}

.jellyai-kb-selected {
  border: 1px solid var(--border-light);
  background: rgba(var(--accent-primary-rgb), .025);
  border-radius: 8px;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  min-height: 58px;
  margin-bottom: 10px;
  padding: 10px 12px;
  display: flex;
}

.jellyai-kb-upload {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  margin-bottom: 10px;
  display: grid;
}

.jellyai-kb-doc-table {
  border: 1px solid var(--border-light);
  border-radius: 8px;
  overflow: hidden;
}

.jellyai-kb-doc-row {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  display: grid;
}

.jellyai-kb-doc-row:not(:last-child) {
  border-bottom: 1px solid var(--border-light);
}

.jellyai-kb-doc-row strong {
  color: var(--text-primary);
  overflow-wrap: anywhere;
  font-size: 13px;
}

.jellyai-kb-doc-row small {
  color: var(--text-muted);
  margin-top: 4px;
  font-size: 11px;
  line-height: 1.45;
  display: block;
}

.jellyai-kb-doc-row small span {
  color: var(--error);
}

.jellyai-kb-doc-actions {
  gap: 8px;
  display: flex;
}

.jellyai-kb-empty {
  color: var(--text-muted);
  border: 1px dashed var(--border-color);
  border-radius: 8px;
  padding: 12px;
  font-size: 12px;
  line-height: 1.5;
}

.jellyai-kb-status {
  color: var(--text-muted);
  min-height: 18px;
  margin-top: 8px;
  font-size: 12px;
}

.jellyai-kb-status.success {
  color: var(--success);
}

.jellyai-kb-status.error {
  color: var(--error);
}

.jellyai-cs-panel {
  display: grid;
  gap: 12px;
}

.jellyai-cs-messages {
  background: var(--bg-secondary);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  min-height: 260px;
  max-height: 480px;
  padding: 14px;
  overflow: auto;
}

.jellyai-cs-message {
  margin-bottom: 12px;
  display: flex;
}

.jellyai-cs-message.user {
  justify-content: flex-end;
}

.jellyai-cs-message.assistant {
  justify-content: flex-start;
}

.jellyai-cs-bubble {
  background: var(--bg-card);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  width: min(760px, 82%);
  padding: 12px;
}

.jellyai-cs-message.user .jellyai-cs-bubble {
  background: var(--msg-user-bg);
}

.jellyai-cs-role {
  color: var(--text-muted);
  margin-bottom: 6px;
  font-size: 11px;
  font-weight: 700;
}

.jellyai-cs-text {
  color: var(--text-primary);
  overflow-wrap: anywhere;
  font-size: 13px;
  line-height: 1.65;
}

.jellyai-cs-sources {
  border-top: 1px solid var(--border-light);
  gap: 8px;
  margin-top: 10px;
  padding-top: 10px;
  display: grid;
}

.jellyai-cs-sources.empty {
  color: var(--warning);
  display: block;
  font-size: 12px;
}

.jellyai-cs-source {
  background: rgba(var(--accent-primary-rgb), .035);
  border: 1px solid var(--border-light);
  border-radius: 6px;
  padding: 8px;
}

.jellyai-cs-source strong {
  color: var(--text-primary);
  font-size: 12px;
  display: block;
}

.jellyai-cs-source span {
  color: var(--text-secondary);
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.5;
  display: block;
}

.jellyai-cs-form {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 10px;
  display: grid;
}

.jellyai-cs-form textarea {
  color: var(--text-primary);
  resize: vertical;
  background: var(--bg-secondary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  min-height: 76px;
  padding: 10px 12px;
  font: inherit;
  font-size: 13px;
  line-height: 1.5;
}

.jellyai-cs-form textarea:focus {
  border-color: var(--accent-primary);
  outline: none;
}

.jellyai-followup-board {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  display: grid;
}

.jellyai-followup-card {
  --lead-color: var(--success);
  background: var(--bg-card);
  border: 1px solid var(--border-color);
  border-left: 3px solid var(--lead-color);
  border-radius: 8px;
  min-width: 0;
  padding: 14px;
}

.jellyai-followup-card.high {
  --lead-color: var(--error);
}

.jellyai-followup-card.medium {
  --lead-color: var(--warning);
}

.jellyai-followup-card.risk {
  --lead-color: var(--error);
}

.jellyai-followup-card-head {
  justify-content: space-between;
  gap: 12px;
  display: flex;
}

.jellyai-followup-card-head strong {
  color: var(--text-primary);
  font-size: 14px;
}

.jellyai-followup-card-head small {
  color: var(--text-muted);
  margin-top: 4px;
  font-size: 11px;
  display: block;
}

.jellyai-followup-card-head span {
  color: var(--lead-color);
  background: rgba(var(--accent-primary-rgb), .04);
  border: 1px solid var(--border-light);
  border-radius: 999px;
  align-self: flex-start;
  flex: none;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 700;
}

.jellyai-followup-section {
  margin-top: 12px;
}

.jellyai-followup-section em {
  color: var(--text-muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 700;
}

.jellyai-followup-section p {
  color: var(--text-secondary);
  overflow-wrap: anywhere;
  margin: 4px 0 0;
  font-size: 12px;
  line-height: 1.55;
}

.jellyai-runtime-grid,
.jellyai-wechat-metrics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  display: grid;
}

.jellyai-wechat-metrics {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.jellyai-runtime-metric,
.jellyai-data-metric {
  border: 1px solid var(--border-light);
  background: rgba(var(--accent-primary-rgb), .025);
  border-radius: 8px;
  padding: 12px;
}

.jellyai-runtime-value {
  color: var(--text-primary);
  margin-top: 6px;
  font-size: 20px;
  font-weight: 800;
  line-height: 1.2;
}

.jellyai-table {
  border: 1px solid var(--border-light);
  border-radius: 8px;
  margin-top: 12px;
  overflow: hidden;
}

.jellyai-table-row {
  grid-template-columns: minmax(160px, 1.4fr) repeat(3, minmax(90px, 1fr));
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  display: grid;
}

.jellyai-table-row:not(:last-child) {
  border-bottom: 1px solid var(--border-light);
}

.jellyai-table-row:hover {
  background: var(--bg-card-hover);
}

.jellyai-table-row span {
  color: var(--text-secondary);
  overflow-wrap: anywhere;
  font-size: 12px;
}

.jellyai-table-row span:first-child {
  color: var(--text-primary);
  font-weight: 700;
}

.jellyai-modal-backdrop {
  z-index: 9999;
  background: rgba(0, 0, 0, .38);
  justify-content: center;
  align-items: center;
  padding: 24px;
  display: flex;
  position: fixed;
  inset: 0;
}

.jellyai-modal-static {
  display: none;
}

.jellyai-modal-toggle {
  opacity: 0;
  pointer-events: none;
  position: fixed;
  width: 1px;
  height: 1px;
}

.jellyai-modal-toggle + .jellyai-modal-backdrop {
  display: none;
}

.jellyai-modal-toggle:checked + .jellyai-modal-backdrop {
  display: flex;
}

.jellyai-modal {
  background: var(--bg-card);
  color: var(--text-primary);
  border: 1px solid var(--border-color);
  border-radius: 8px;
  width: min(680px, calc(100vw - 32px));
  max-height: min(760px, calc(100vh - 40px));
  box-shadow: 0 20px 60px rgba(0, 0, 0, .22);
  flex-direction: column;
  display: flex;
  overflow: hidden;
}

.jellyai-modal-head {
  border-bottom: 1px solid var(--border-color);
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  display: flex;
}

.jellyai-modal-title {
  color: var(--text-primary);
  font-size: 15px;
  font-weight: 800;
}

.jellyai-modal-close {
  appearance: none;
  color: var(--text-muted);
  cursor: pointer;
  background: transparent;
  border: none;
  border-radius: 6px;
  justify-content: center;
  align-items: center;
  width: 28px;
  height: 28px;
  font-size: 22px;
  line-height: 24px;
  display: flex;
}

.jellyai-modal-close:hover {
  color: var(--text-primary);
  background: rgba(var(--accent-primary-rgb), .06);
}

.jellyai-modal-body {
  padding: 16px 18px;
  overflow-y: auto;
}

.jellyai-modal-actions {
  border-top: 1px solid var(--border-color);
  justify-content: flex-end;
  gap: 10px;
  padding: 14px 18px;
  display: flex;
}

.jellyai-modal-split {
  grid-template-columns: 180px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
  display: grid;
}

.jellyai-qr {
  background:
    linear-gradient(90deg, #111 10px, transparent 10px 20px, #111 20px 30px, transparent 30px 40px),
    linear-gradient(#111 10px, transparent 10px 20px, #111 20px 30px, transparent 30px 40px),
    #fff;
  border: 10px solid #fff;
  box-shadow: inset 0 0 0 1px #111, 0 0 0 1px var(--border-color);
  border-radius: 6px;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  width: 168px;
  height: 168px;
  padding: 12px;
  display: grid;
}

.jellyai-qr div {
  background: #111;
  border-radius: 2px;
}

.jellyai-modal-hint {
  color: var(--text-muted);
  margin-top: 10px;
  font-size: 12px;
  line-height: 1.5;
}

.jellyai-modal-form {
  gap: 12px;
  display: grid;
}

.jellyai-modal-field {
  gap: 6px;
  display: grid;
}

.jellyai-modal-field span {
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
}

.jellyai-modal-field input {
  color: var(--text-primary);
  background: var(--bg-input);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  min-height: 34px;
  padding: 7px 10px;
  font: inherit;
  font-size: 13px;
}

.jellyai-modal-field input:focus {
  border-color: var(--accent-muted);
  outline: none;
}

.jellyai-modal-state {
  color: var(--success);
  background: rgba(var(--success-rgb), .1);
  border: 1px solid rgba(var(--success-rgb), .22);
  border-radius: 6px;
  padding: 9px 10px;
  font-size: 12px;
  font-weight: 600;
}

.jellyai-upload-box {
  color: var(--text-secondary);
  background: rgba(var(--accent-primary-rgb), .03);
  border: 1px dashed var(--border-color);
  border-radius: 8px;
  padding: 14px;
}

.jellyai-upload-input {
  width: 100%;
  margin-bottom: 10px;
  font-size: 12px;
}

.jellyai-upload-title {
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
}

.jellyai-upload-desc {
  color: var(--text-muted);
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.5;
}

.jellyai-upload-list {
  border: 1px solid var(--border-light);
  border-radius: 8px;
  overflow: hidden;
}

.jellyai-upload-list div {
  justify-content: space-between;
  gap: 12px;
  padding: 9px 10px;
  color: var(--text-secondary);
  font-size: 12px;
  display: flex;
}

.jellyai-upload-list div:not(:last-child) {
  border-bottom: 1px solid var(--border-light);
}

.jellyai-upload-list span {
  color: var(--text-muted);
  flex: none;
}

.jellyai-modal-option {
  border: 1px solid var(--border-light);
  background: rgba(var(--accent-primary-rgb), .025);
  border-radius: 8px;
  align-items: flex-start;
  gap: 10px;
  padding: 10px;
  display: flex;
}

.jellyai-modal-option input {
  margin-top: 3px;
}

.jellyai-modal-option strong {
  color: var(--text-primary);
  display: block;
  font-size: 13px;
}

.jellyai-modal-option small {
  color: var(--text-secondary);
  margin-top: 3px;
  font-size: 12px;
  line-height: 1.5;
  display: block;
}

.jellyai-modal-flow {
  max-height: 430px;
  overflow-y: auto;
}

@media (max-width: 1060px) {
  .jellyai-demo-grid,
  .jellyai-demo-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .jellyai-demo-columns {
    grid-template-columns: 1fr;
  }

  .jellyai-wechat-metrics {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 768px) {
  .jellyai-demo-header {
    align-items: flex-start;
    flex-direction: column;
    padding: 16px 12px 16px 52px;
  }

  .jellyai-demo-content {
    padding: 12px;
  }

  .jellyai-demo-grid,
  .jellyai-demo-board {
    grid-template-columns: 1fr;
  }

  .jellyai-runtime-grid,
  .jellyai-wechat-metrics,
  .jellyai-service-stats,
  .jellyai-modal-split {
    grid-template-columns: 1fr;
  }

  .jellyai-table-row {
    grid-template-columns: 1fr 1fr;
  }

  .jellyai-chat-credit-bar {
    align-items: stretch;
    flex-direction: column;
    padding: 12px 12px 12px 52px;
  }

  .jellyai-chat-credit-side {
    justify-content: flex-start;
  }

  .jellyai-demo-header-actions,
  .jellyai-demo-action-btn,
  .jellyai-demo-inline-btn {
    width: 100%;
  }
}

/* 0.6.3 sidebar reset: keep the author's native nav behavior. */
.sidebar .jellyai-extra-nav,
.sidebar .jellyai-original-skill-nav,
.app-sidebar .jellyai-extra-nav,
.app-sidebar .jellyai-original-skill-nav,
aside .jellyai-extra-nav,
aside .jellyai-original-skill-nav {
  display: flex !important;
}

.jellyai-more-toggle,
.jellyai-more-menu,
.jellyai-chat-credit-bar {
  display: none !important;
}

.jellyai-demo-bottom-group {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--border-color);
}

.jellyai-demo-bottom-group .jellyai-demo-nav {
  text-decoration: none !important;
}

.jellyai-composer-lift,
body .chat-input-area {
  transform: none !important;
  margin-bottom: 0 !important;
  box-shadow: none !important;
}

body .message-list {
  padding-bottom: initial !important;
}

.fun-link,
.github-link,
.website-link,
a[href*="apikey.fun"],
a[href*="github.com/EKKOLearnAI/hermes-web-ui"],
a[href*="ekkolearnai.com"] {
  display: none !important;
}

.jellyai-cs-form-actions {
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 10px;
  display: flex;
}

.jellyai-cs-form-actions label {
  color: var(--text-secondary);
  align-items: center;
  gap: 8px;
  font-size: 13px;
  display: flex;
}

.jellyai-wecom-bind {
  gap: 14px;
  display: grid;
}

.jellyai-wecom-help {
  color: var(--text-secondary);
  background: rgba(var(--accent-primary-rgb), .035);
  border: 1px solid var(--border-light);
  border-radius: 8px;
  gap: 5px;
  padding: 10px 12px;
  display: grid;
}

.jellyai-wecom-help strong {
  color: var(--text-primary);
  font-size: 13px;
}

.jellyai-wecom-help span {
  font-size: 12px;
  line-height: 1.55;
}

.jellyai-wecom-qr-panel,
.jellyai-wecom-direct-form {
  border: 1px solid var(--border-light);
  background: var(--bg-secondary);
  border-radius: 8px;
  gap: 10px;
  padding: 12px;
  display: grid;
}

.jellyai-wecom-qr {
  border: 1px dashed var(--border-color);
  background: var(--bg-card);
  border-radius: 8px;
  place-items: center;
  min-height: 172px;
  padding: 12px;
  display: grid;
}

.jellyai-wecom-qr img {
  background: #fff;
  border-radius: 6px;
  width: 150px;
  height: 150px;
  padding: 6px;
}

.jellyai-wecom-url {
  color: var(--text-secondary);
  background: var(--bg-input);
  border: 1px solid var(--border-color);
  border-radius: 6px;
  min-height: 34px;
  padding: 7px 10px;
  font: inherit;
  font-size: 12px;
}

.jellyai-wecom-list {
  border: 1px solid var(--border-light);
  border-radius: 8px;
  overflow: hidden;
}

.jellyai-wecom-row {
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  display: flex;
}

.jellyai-wecom-row:not(:last-child) {
  border-bottom: 1px solid var(--border-light);
}

.jellyai-wecom-row strong {
  color: var(--text-primary);
  font-size: 13px;
  display: block;
}

.jellyai-wecom-row small {
  color: var(--text-secondary);
  margin-top: 4px;
  font-size: 12px;
  line-height: 1.45;
  display: block;
}

.jellyai-wecom-row small span {
  color: var(--error);
}

.jellyai-wecom-actions {
  flex: none;
  gap: 8px;
  display: flex;
}

.jellyai-demo-inline-btn.danger {
  color: var(--error);
  border-color: rgba(var(--error-rgb), .28);
}

@media (max-width: 768px) {
  .jellyai-cs-form-actions,
  .jellyai-wecom-row,
  .jellyai-wecom-actions {
    align-items: stretch;
    flex-direction: column;
  }
}
