/* st-redesign.css — Redesign v2, scrollbars, focus styles, skeleton loading, translation error */
/* ===== Scrollbar styling ===== */
.st-source-editor .ql-container::-webkit-scrollbar,
.st-target-output .ql-container::-webkit-scrollbar,
.st-drawer-content::-webkit-scrollbar,
.st-lang-dropdown::-webkit-scrollbar {
  width: 4px;
}

.st-source-editor .ql-container::-webkit-scrollbar-track,
.st-target-output .ql-container::-webkit-scrollbar-track,
.st-drawer-content::-webkit-scrollbar-track,
.st-lang-dropdown::-webkit-scrollbar-track {
  background: transparent;
}

.st-source-editor .ql-container::-webkit-scrollbar-thumb,
.st-target-output .ql-container::-webkit-scrollbar-thumb,
.st-drawer-content::-webkit-scrollbar-thumb,
.st-lang-dropdown::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.08);
  border-radius: 4px;
}

.st-source-editor .ql-container::-webkit-scrollbar-thumb:hover,
.st-target-output .ql-container::-webkit-scrollbar-thumb:hover,
.st-drawer-content::-webkit-scrollbar-thumb:hover,
.st-lang-dropdown::-webkit-scrollbar-thumb:hover {
  background: rgba(0, 0, 0, 0.15);
}

/* Firefox thin scrollbar override */
.st-source-editor .ql-container,
.st-target-output .ql-container {
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.08) transparent;
}

/* ===== Focus styles (accessibility) ===== */
.st-toolbar-btn:focus-visible,
.st-lang-selector:focus-visible,
.st-swap-btn:focus-visible,
.st-overflow-btn:focus-visible,
.st-translate-btn:focus-visible,
.st-tone-segment .st-tone-preset-btn:focus-visible,
.st-drawer-tab:focus-visible,
.st-drawer-close:focus-visible,
.st-nav-btn:focus-visible,
.st-status-icon-btn:focus-visible,
.st-dropdown-item:focus-visible,
.st-lang-option:focus-visible {
  outline: 2px solid rgba(0, 0, 0, 0.15);
  outline-offset: 2px;
}

.st-source-editor .ql-editor:focus-visible {
  outline: none;
  box-shadow: none;
}

/* ===== Skeleton loading animation ===== */
@keyframes st-shimmer {
  0% { background-position: -400px 0; }
  100% { background-position: 400px 0; }
}

.st-loading .st-target-output {
  position: relative;
}

.st-skeleton {
  position: absolute;
  inset: 0;
  padding: var(--space-4);
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--color-card);
  z-index: 2;
}

.st-skeleton-line {
  height: 14px;
  border-radius: 6px;
  background: linear-gradient(
    90deg,
    var(--color-border) 25%,
    var(--color-bg) 50%,
    var(--color-border) 75%
  );
  background-size: 800px 100%;
  animation: st-shimmer 1.5s infinite ease-in-out;
  opacity: 0.6;
}

/* ===== Translation error ===== */
.st-translation-error {
  display: flex;
  align-items: center;
  padding: var(--space-4);
  color: var(--color-error);
  font-size: var(--font-size-sm);
  font-weight: 500;
  line-height: 1.5;
}


/* =================================================================
 *  REDESIGN v2 — Clean layout with progressive disclosure
 *  Removes top toolbars, adds footer bars, overlay clear button
 * ================================================================= */

/* --- Hide old top toolbars and status bar --- */
.st-panel-toolbar {
  display: none;
}

.st-status-bar {
  display: none;
}

/* --- Language bar divider --- */
.st-lang-bar-divider {
  width: 1px;
  height: 24px;
  background: var(--color-border);
  margin-left: auto;
  flex-shrink: 0;
}

/* --- Editor wrap (enables overlay positioning) --- */
.st-editor-wrap {
  position: relative;
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}

/* --- Clear X button (overlay inside source editor) --- */
.st-clear-x {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-full);
  background: var(--color-bg);
  color: var(--color-text-secondary);
  border: 1px solid var(--color-border);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
  cursor: pointer;
  z-index: 5;
  opacity: 1;
  transition: all var(--transition);
}

.st-clear-x:hover {
  background: var(--color-card);
  color: var(--color-text-primary);
  border-color: rgba(0, 0, 0, 0.2);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
}

.st-clear-x:disabled {
  opacity: 0;
  pointer-events: none;
}

/* --- Source header bar --- */
.st-source-header {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  gap: 4px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  background: var(--color-card);
  border-radius: 8px 8px 0 0;
  flex-shrink: 0;
  height: 52px;
}

/* --- Footer button (shared style for source + target footer) --- */
.st-footer-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  flex-shrink: 0;
  font-family: inherit;
  font-size: 13px;
  line-height: 1;
}

.st-footer-btn svg {
  flex-shrink: 0;
}

.st-footer-btn:hover:not(:disabled) {
  background: rgba(0, 0, 0, 0.05);
  color: var(--color-text-primary);
}

.st-footer-btn:active:not(:disabled) {
  background: rgba(0, 0, 0, 0.08);
  color: var(--color-text-primary);
}

.st-footer-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.st-footer-btn.active {
  background: rgba(0, 0, 0, 0.08);
  color: var(--color-text-primary);
}

/* STT active (footer mic button) */
.st-footer-btn.st-stt-active {
  background: rgba(0, 0, 0, 0.08);
  color: var(--color-text-primary);
}

/* Mic language badge — small floating pill next to mic */
.st-mic-lang-badge {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 8px 0 6px;
  margin-left: 4px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--color-text-primary);
  background: rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 11px;
  white-space: nowrap;
  animation: st-mic-badge-in 0.25s ease-out;
  cursor: default;
}
/* Pulsing rec dot inside badge */
.st-mic-lang-badge::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 5px;
  border-radius: 50%;
  background: #ef4444;
  animation: st-rec-dot 1.4s ease-in-out infinite;
  flex-shrink: 0;
}

@keyframes st-mic-badge-in {
  from { opacity: 0; transform: scale(0.85); }
  to   { opacity: 1; transform: scale(1); }
}

/* Quick mic language picker popover */
.st-mic-lang-picker {
  position: absolute;
  top: 100%;
  left: 0;
  z-index: 100;
  margin-top: 6px;
  padding: 10px 12px;
  background: var(--color-bg, #fff);
  border: 1px solid var(--color-border, #e0e0e0);
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
  animation: st-mic-badge-in 0.15s ease-out;
  max-width: 340px;
  min-width: 200px;
}

.st-mic-lang-picker-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-secondary);
  margin-bottom: 8px;
  white-space: nowrap;
}

.st-mic-lang-picker-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  max-height: 200px;
  overflow-y: auto;
}

.st-mic-lang-picker-btn {
  padding: 6px 12px;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-primary);
  background: rgba(0, 0, 0, 0.04);
  border: 1px solid transparent;
  border-radius: 8px;
  cursor: pointer;
  white-space: nowrap;
  transition: background 180ms ease, border-color 180ms ease;
}

.st-mic-lang-picker-btn:hover {
  background: rgba(0, 0, 0, 0.08);
  border-color: rgba(0, 0, 0, 0.2);
  color: var(--color-text-primary);
}

/* Detected language hint on source language button */
.st-detected-hint {
  font-size: 11px;
  font-weight: 400;
  color: var(--color-text-secondary);
  margin-left: 4px;
  opacity: 0.7;
}

/* --- Format button group (subtle, secondary styling) --- */
.st-format-group {
  display: flex;
  align-items: center;
  gap: 2px;
  margin-left: 4px;
  padding-left: 8px;
  border-left: 1px solid var(--color-border);
}

.st-format-btn {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: none;
  background: transparent;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  font-family: system-ui, -apple-system, sans-serif;
  color: var(--color-text-secondary);
  opacity: 0.4;
  transition: all 180ms ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.st-format-btn:hover {
  opacity: 1;
  background: rgba(0, 0, 0, 0.05);
  color: var(--color-text-primary);
}

/* Active state when editor has text */
.st-editor-wrap:has(.ql-editor:not(.ql-blank)) .st-format-btn {
  opacity: 1;
  color: var(--color-text-primary);
}

/* --- Floating translate button (inside editor area, above format toolbar) --- */
.st-floating-translate {
  position: absolute;
  bottom: 72px;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  z-index: 11;
  padding: 10px 32px;
  background: var(--color-primary);
  color: #fff;
  font-size: var(--font-size-sm);
  font-weight: 600;
  font-family: inherit;
  border-radius: 24px;
  border: none;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(var(--color-primary-rgb, 105, 108, 255), 0.4);
  transition: all 180ms ease;
  opacity: 0;
  pointer-events: none;
  line-height: 1;
}

.st-floating-translate[style*="display: none"] {
  /* When JS hides via display:none, keep hidden */
}

.st-floating-translate:not([style*="display: none"]):not([style*="display:none"]) {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.st-floating-translate:hover:not(:disabled) {
  box-shadow: 0 6px 20px rgba(var(--color-primary-rgb, 105, 108, 255), 0.5);
  transform: translateX(-50%) translateY(-2px);
}

.st-floating-translate:active:not(:disabled) {
  transform: translateX(-50%) translateY(0) scale(0.97);
}

.st-floating-translate:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  box-shadow: none;
}

/* --- Clear button in source header (pushed to right) --- */
.st-header-clear-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  margin-left: auto;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  flex-shrink: 0;
  opacity: 0;
  pointer-events: none;
}

.st-header-clear-btn:not(:disabled) {
  opacity: 1;
  pointer-events: auto;
}

.st-header-clear-btn:hover:not(:disabled) {
  background: rgba(255, 62, 29, 0.08);
  color: var(--color-error);
}

/* Old header translate button removed — now using .st-floating-translate */

/* --- Source footer bar (floating format toolbar, matches target floating-actions) --- */
.st-source-footer {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  background: transparent;
  pointer-events: none;
}

.st-source-footer .st-format-group {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 6px 16px;
  margin-left: 0;
  padding-left: 16px;
  border-left: none;
  background: var(--color-card);
  border-radius: 24px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06), 0 0 0 1px rgba(0, 0, 0, 0.04);
  border: none;
  pointer-events: auto;
}

/* --- Target header bar (tone dropdown, always visible) --- */
.st-target-header {
  display: flex;
  align-items: center;
  padding: 8px 16px;
  gap: 8px;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  background: var(--color-bg);
  border-radius: 8px 8px 0 0;
  flex-shrink: 0;
  height: 52px;
}

/* Response nav — floating above the action bar */
.st-target-wrap > .st-response-nav {
  position: absolute;
  bottom: 72px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 12px;
  background: transparent;
  border-radius: 20px;
  font-size: 12px;
  color: var(--color-text-secondary);
  white-space: nowrap;
  z-index: 9;
}

.st-target-wrap > .st-response-nav .st-nav-btn {
  width: 26px;
  height: 26px;
  font-size: 13px;
  border-radius: 50%;
  border: none;
  background: transparent;
  color: var(--color-text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
}

.st-target-wrap > .st-response-nav .st-nav-btn:hover:not(:disabled) {
  background: rgba(0, 0, 0, 0.05);
  color: var(--color-text-primary);
}

.st-target-wrap > .st-response-nav .st-nav-btn:disabled {
  opacity: 0.3;
  cursor: default;
}

/* --- Tone dropdown (compact chip → expandable) --- */
.st-tone-dropdown {
  position: relative;
}

.st-tone-trigger {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  background: var(--color-bg);
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: 20px;
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-primary);
  cursor: pointer;
  transition: all var(--transition);
  white-space: nowrap;
}

.st-tone-trigger:hover {
  border-color: rgba(0, 0, 0, 0.2);
  color: var(--color-text-primary);
}

.st-tone-trigger .st-chevron {
  transition: transform 180ms ease;
}

.st-tone-dropdown.open .st-tone-trigger .st-chevron {
  transform: rotate(180deg);
}

.st-tone-dropdown .st-tone-segment {
  display: none;
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  background: var(--color-card);
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 0 0 1px rgba(0, 0, 0, 0.06);
  padding: 4px;
  z-index: 20;
  flex-direction: column;
  min-width: 160px;
}

.st-tone-dropdown.open .st-tone-segment {
  display: flex;
}

.st-tone-dropdown .st-tone-segment .st-tone-preset-btn {
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  text-align: left;
  width: 100%;
  color: var(--color-text-secondary);
  background: transparent;
  transition: all var(--transition);
}

.st-tone-dropdown .st-tone-segment .st-tone-preset-btn:hover:not(.active) {
  background: var(--color-bg);
  color: var(--color-text-primary);
}

.st-tone-dropdown .st-tone-segment .st-tone-preset-btn.active {
  background: var(--color-text-primary);
  color: #fff;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

/* --- Target content wrapper (relative for floating bar) --- */
.st-target-wrap {
  position: relative;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

/* --- Floating action bar (modern pill) --- */
.st-floating-actions {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  background: var(--color-card);
  border-radius: 24px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10), 0 1px 4px rgba(0, 0, 0, 0.06);
  border: 1px solid rgba(0, 0, 0, 0.06);
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: opacity 180ms ease, transform 180ms ease;
}

/* Show floating bar when copy is enabled */
.st-floating-actions:has(#copyBtn:not(:disabled)) {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

/* --- Floating action button --- */
.st-float-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  color: var(--color-text-secondary);
  background: transparent;
  border: none;
  cursor: pointer;
  transition: all var(--transition);
  flex-shrink: 0;
}

.st-float-btn svg {
  flex-shrink: 0;
}

.st-float-btn:hover:not(:disabled) {
  background: rgba(0, 0, 0, 0.05);
  color: var(--color-text-primary);
}

.st-float-btn:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}

.st-float-btn.st-float-chat {
  color: var(--color-primary);
}

.st-float-btn.st-float-chat:hover {
  background: var(--color-primary);
  color: #fff;
}

.st-float-btn.st-float-chat.active {
  background: var(--color-primary);
  color: #fff;
}

/* Divider line inside floating bar */
.st-float-divider {
  width: 1px;
  height: 20px;
  background: var(--color-border);
  flex-shrink: 0;
}

/* Download dropdown from floating bar */
.st-floating-actions .st-download-wrap {
  position: relative;
}

.st-floating-actions .st-download-dropdown {
  bottom: 100%;
  top: auto;
  margin-bottom: 8px;
  margin-top: 0;
}

/* Hide responseNav when download dropdown is open to prevent overlap */
.st-target-wrap:has(.st-download-dropdown.open) > .st-response-nav {
  visibility: hidden;
  pointer-events: none;
}

.st-target-header .st-chat-pill span {
  display: none;
}

.st-target-header .st-chat-pill {
  width: 36px;
  height: 36px;
  padding: 0;
  border-radius: var(--radius-md);
  justify-content: center;
}

/* --- Chat pill button --- */
.st-chat-pill {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 20px;
  background: rgba(0, 0, 0, 0.05);
  color: var(--color-text-primary);
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  flex-shrink: 0;
  transition: all var(--transition);
  line-height: 1;
}

.st-chat-pill svg {
  flex-shrink: 0;
}

.st-chat-pill:hover {
  background: var(--color-text-primary);
  color: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

.st-chat-pill.active {
  background: var(--color-text-primary);
  color: #fff;
}

/* Old target-header download/response-nav rules removed — now handled by .st-floating-actions and .st-target-header */

/* =================================================================
 *  REDESIGN v2 — Dark mode additions
 * ================================================================= */

/* prefers-color-scheme redesign v2 removed — [data-theme="dark"] block below is the single source of truth */

[data-theme="dark"] {
  .st-clear-x {
    background: var(--color-bg);
    border-color: rgba(255, 255, 255, 0.1);
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
  }

  .st-clear-x:hover {
    background: var(--st-hover-dark);
    border-color: rgba(255, 255, 255, 0.2);
  }

  .st-source-header,
  .st-target-header {
    border-color: rgba(255, 255, 255, 0.06);
  }

  .st-source-footer .st-format-group {
    background: var(--color-card);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.06);
  }

  .st-format-group {
    border-left-color: rgba(255, 255, 255, 0.08);
  }

  .st-footer-btn:hover:not(:disabled) {
    background: var(--st-hover-dark);
  }

  .st-float-btn:hover:not(:disabled) {
    background: var(--st-hover-dark);
  }

  .st-float-btn.st-float-chat:hover {
    background: var(--color-primary);
    color: #fff;
  }

  .st-floating-actions {
    background: var(--color-card);
    border-color: rgba(255, 255, 255, 0.08);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.25), 0 1px 4px rgba(0, 0, 0, 0.15);
  }

  .st-target-wrap > .st-response-nav {
    background: transparent;
  }

  .st-target-wrap > .st-response-nav .st-nav-btn:hover:not(:disabled) {
    background: var(--st-hover-dark);
  }

  .st-tone-trigger {
    background: var(--st-hover-dark);
    border-color: rgba(255, 255, 255, 0.08);
    color: var(--color-text-primary);
  }

  .st-tone-trigger:hover {
    border-color: rgba(255, 255, 255, 0.2);
    color: var(--color-text-primary);
  }

  .st-tone-dropdown .st-tone-segment {
    background: var(--color-card);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(255, 255, 255, 0.06);
  }

  .st-tone-dropdown .st-tone-segment .st-tone-preset-btn:hover:not(.active) {
    background: var(--st-hover-dark);
  }

  .st-floating-translate {
    box-shadow: 0 4px 16px rgba(var(--color-primary-rgb, 105, 108, 255), 0.5);
  }

  .st-float-divider {
    background: rgba(255, 255, 255, 0.08);
  }
}

/* =================================================================
 *  REDESIGN v2 — Mobile responsive
 * ================================================================= */

@media (max-width: 1023px) and (min-width: 768px) {
  .st-source-header {
    padding: 6px 12px;
  }

  .st-source-footer {
    display: none !important;
  }

  .st-floating-translate {
    bottom: 16px;
  }

  .st-floating-actions {
    padding: 4px 8px;
    gap: 2px;
  }

  .st-float-btn {
    width: 32px;
    height: 32px;
  }
}

@media (max-width: 767px) {
  /* Change 1: Compact source header — 52px → 40px */
  .st-source-header {
    padding: 4px 10px;
    gap: 2px;
    height: 40px;
  }

  .st-source-header .st-footer-btn {
    width: 32px;
    height: 32px;
  }

  .st-source-footer {
    display: none !important;
  }

  .st-floating-translate {
    bottom: 16px;
    padding: 8px 24px;
    font-size: var(--font-size-xs);
  }

  .st-clear-x {
    top: 8px;
    right: 8px;
    width: 28px;
    height: 28px;
  }

  .st-translate-btn {
    padding: 6px 16px;
    font-size: var(--font-size-xs);
  }

  /* Change 2: Give target panel more space (source 45, target 55) */
  .st-source-panel {
    flex: 45;
  }

  .st-target-panel {
    flex: 55;
  }

  /* Change 3: Compact target header — 52px → 36px */
  .st-target-header {
    padding: 4px 12px;
    height: 36px;
    gap: 4px;
  }

  /* Change 4: Lift floating actions above mobile nav (82px) */
  .st-floating-actions {
    padding: 4px 6px;
    gap: 2px;
    bottom: 24px;
  }

  .st-float-btn {
    width: 30px;
    height: 30px;
  }

  .st-target-wrap > .st-response-nav {
    display: none;
  }
}

/* ===== Bundle overrides: neutralise remaining primary/red colors ===== */

/* Collapsed sidebar — active option: red → neutral */
.collapsed-option.active {
  background-color: rgba(0, 0, 0, 0.06) !important;
  color: var(--color-text-primary) !important;
}

/* Dropdown option hover: pink tint → neutral */
.hk-dropdown-option:hover {
  background-color: rgba(0, 0, 0, 0.04) !important;
}

/* Gradient text on primary labels → solid neutral */
.hk-dropdown-option-primary span,
.sidebar-dropdown-items .hk-dropdown-option-primary span {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: var(--color-text-primary) !important;
  color: var(--color-text-primary) !important;
}

/* Robot bubble gradient text → solid neutral */
.sidebar-robot-bubble .bubble-text,
span.sidebar-robot-input-top-text {
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  -webkit-text-fill-color: var(--color-text-secondary) !important;
  color: var(--color-text-secondary) !important;
}

/* Gradient loader → neutral */
.gradient-loader,
.gradient-loader-smart {
  background: linear-gradient(90deg, rgba(0,0,0,0.1), rgba(0,0,0,0.3), rgba(0,0,0,0.1)) !important;
  background-size: 200% 100% !important;
}

/* Header gradient title → solid neutral */
.hamdan-header-left .hamdan-header-title {
  background: none !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: var(--color-text-primary) !important;
  color: var(--color-text-primary) !important;
}

/* Tutorial hover → neutral */
#show-sidebar-tutorial-btn:hover,
#show-tutorial-btn:hover {
  color: var(--color-text-primary) !important;
}
#show-sidebar-tutorial-btn:hover .sidebar-tutorial-icon path,
#show-tutorial-btn:hover .tutorial-icon path {
  fill: var(--color-text-primary) !important;
}

/* TTS read button playing/paused → neutral (not red) */
.message-actions .action-icon.read-btn.playing,
.message-actions .action-icon.read-btn.paused {
  background: rgba(0, 0, 0, 0.08) !important;
  color: var(--color-text-primary) !important;
}
.message-actions .action-icon.read-btn.playing:hover,
.message-actions .action-icon.read-btn.paused:hover {
  background: rgba(0, 0, 0, 0.12) !important;
  color: var(--color-text-primary) !important;
}
.message-actions .action-icon.read-btn.playing svg,
.message-actions .action-icon.read-btn.paused svg {
  stroke: currentColor !important;
}

/* Sidebar badge → neutral dark pill */
.sidebar-badge {
  background: var(--color-text-primary) !important;
}

/* Dark mode — collapsed sidebar active */
[data-theme="dark"] .collapsed-option.active {
  background-color: rgba(255, 255, 255, 0.1) !important;
  color: var(--color-text-primary) !important;
}

/* Dark mode — dropdown hover */
[data-theme="dark"] .hk-dropdown-option:hover {
  background-color: rgba(255, 255, 255, 0.06) !important;
}

/* Dark mode — gradient loader */
[data-theme="dark"] .gradient-loader,
[data-theme="dark"] .gradient-loader-smart {
  background: linear-gradient(90deg, rgba(255,255,255,0.1), rgba(255,255,255,0.25), rgba(255,255,255,0.1)) !important;
}

/* Dark mode — TTS read btn */
[data-theme="dark"] .message-actions .action-icon.read-btn.playing,
[data-theme="dark"] .message-actions .action-icon.read-btn.paused {
  background: rgba(255, 255, 255, 0.1) !important;
}
