/* ==========================================================
   Knowledge Override Page Styles
   ========================================================== */

/* --- Tabs --- */

.ko-tabs {
  display: flex;
  gap: var(--space-xs);
  margin-bottom: var(--space-md);
}

.ko-tab-btn {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-xs) var(--space-md);
  border: 1px solid var(--tg-theme-section-separator-color);
  border-radius: var(--radius-full);
  background: var(--tg-theme-secondary-bg-color);
  color: var(--tg-theme-hint-color);
  font-size: var(--font-xs);
  cursor: pointer;
  transition: all var(--transition-fast);
}

.ko-tab-btn.active {
  background: var(--tg-theme-button-color);
  color: var(--tg-theme-button-text-color);
  border-color: var(--tg-theme-button-color);
}

.ko-tab-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 6px;
  border-radius: var(--radius-full);
  background: rgba(0, 0, 0, 0.1);
  font-size: 11px;
  font-weight: var(--weight-bold);
}

.ko-tab-btn.active .ko-tab-count {
  background: rgba(255, 255, 255, 0.25);
}

/* --- List --- */

.ko-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-xs);
}

.ko-item {
  display: flex;
  align-items: center;
  padding: var(--space-md);
  background: var(--tg-theme-secondary-bg-color);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: opacity var(--transition-fast);
  gap: var(--space-sm);
}

.ko-item:active {
  opacity: 0.7;
}

.ko-item-emoji {
  font-size: 28px;
  line-height: 1;
  flex-shrink: 0;
}

.ko-item-info {
  flex: 1;
  min-width: 0;
}

.ko-item-user {
  font-size: var(--font-sm);
  font-weight: var(--weight-semibold);
  color: var(--tg-theme-text-color);
}

.ko-item-preview {
  font-size: var(--font-xs);
  color: var(--tg-theme-hint-color);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ko-item-meta {
  font-size: 11px;
  color: var(--tg-theme-hint-color);
  margin-top: 2px;
}

.ko-item-badge {
  font-size: 20px;
  flex-shrink: 0;
}

.ko-empty {
  text-align: center;
  padding: var(--space-xl);
  color: var(--tg-theme-hint-color);
  font-size: var(--font-sm);
}

/* --- Detail: Meta --- */

.ko-detail-meta {
  padding: var(--space-md);
  background: var(--tg-theme-secondary-bg-color);
  border-radius: var(--radius-md);
  margin-bottom: var(--space-md);
}

.ko-detail-meta-row {
  font-size: var(--font-sm);
  color: var(--tg-theme-text-color);
  line-height: 1.6;
}

/* --- Detail: AI Decision --- */

.ko-ai-section {
  margin-bottom: var(--space-md);
}

.ko-ai-info {
  padding: var(--space-md);
  background: var(--tg-theme-secondary-bg-color);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--tg-theme-button-color);
}

.ko-ai-status {
  font-size: var(--font-sm);
  font-weight: var(--weight-semibold);
  color: var(--tg-theme-text-color);
}

.ko-ai-pillar {
  font-size: var(--font-xs);
  color: var(--tg-theme-hint-color);
  margin-top: var(--space-xs);
}

.ko-ai-hp {
  font-size: var(--font-xs);
  color: #34c759;
  margin-top: var(--space-xs);
  font-weight: var(--weight-semibold);
}

/* --- Detail: Content --- */

.ko-detail-text {
  padding: var(--space-md);
  background: var(--tg-theme-secondary-bg-color);
  border-radius: var(--radius-md);
  font-size: var(--font-sm);
  color: var(--tg-theme-text-color);
  line-height: 1.7;
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 400px;
  overflow-y: auto;
}

/* --- Telegram Link --- */

.ko-telegram-link {
  margin-bottom: var(--space-md);
}

.ko-telegram-btn {
  display: block;
  text-align: center;
  padding: var(--space-sm) var(--space-md);
  background: var(--tg-theme-secondary-bg-color);
  color: var(--tg-theme-link-color, var(--tg-theme-button-color));
  border-radius: var(--radius-md);
  font-size: var(--font-sm);
  text-decoration: none;
  transition: opacity var(--transition-fast);
}

.ko-telegram-btn:active {
  opacity: 0.7;
}

/* --- Actions --- */

.ko-actions {
  margin-top: var(--space-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

.ko-actions-label {
  font-size: var(--font-xs);
  color: var(--tg-theme-hint-color);
  font-weight: var(--weight-semibold);
}

/* --- Pillar Selector --- */

.ko-pillar-wrap {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-xs);
  margin-bottom: var(--space-sm);
}

.ko-pillar-btn {
  padding: var(--space-xs) var(--space-sm);
  border: 1px solid var(--tg-theme-section-separator-color);
  border-radius: var(--radius-md);
  background: var(--tg-theme-secondary-bg-color);
  color: var(--tg-theme-hint-color);
  font-size: var(--font-xs);
  cursor: pointer;
  text-align: center;
  transition: all var(--transition-fast);
}

.ko-pillar-btn.active {
  background: var(--tg-theme-button-color);
  color: var(--tg-theme-button-text-color);
  border-color: var(--tg-theme-button-color);
}

/* --- Action Buttons --- */

.ko-approve-btn {
  width: 100%;
  padding: var(--space-md);
  background: #34c759;
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-md);
  font-weight: var(--weight-bold);
  cursor: pointer;
  transition: opacity var(--transition-fast);
}

.ko-approve-btn:active {
  opacity: 0.7;
}

.ko-approve-btn:disabled {
  opacity: 0.5;
  cursor: default;
}

.ko-change-pillar-btn {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: var(--tg-theme-button-color);
  color: var(--tg-theme-button-text-color);
  border: none;
  border-radius: var(--radius-md);
  font-size: var(--font-sm);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  transition: opacity var(--transition-fast);
}

.ko-change-pillar-btn:active {
  opacity: 0.7;
}

.ko-change-pillar-btn:disabled {
  opacity: 0.5;
  cursor: default;
}

.ko-reject-btn {
  width: 100%;
  padding: var(--space-sm) var(--space-md);
  background: none;
  color: #ff3b30;
  border: 1px solid #ff3b30;
  border-radius: var(--radius-md);
  font-size: var(--font-sm);
  font-weight: var(--weight-semibold);
  cursor: pointer;
  transition: opacity var(--transition-fast);
}

.ko-reject-btn:active {
  opacity: 0.7;
}

.ko-reject-btn:disabled {
  opacity: 0.5;
  cursor: default;
}
