/* ═══════════════════════════════════════════════════════════════
   dich-phantich.css — Module "Dịch & Phân Tích" Xianxia 3D Design
   Thay thế CSS cũ từ dict-page.css (translate + analyzer sections)
   ═══════════════════════════════════════════════════════════════ */

/* ─── CSS VARIABLES ─────────────────────────────────────────── */
#tab-dich-phantich {
  --dp-card-bg:        rgba(255,255,255,0.04);
  --dp-card-border:    rgba(255,255,255,0.10);
  --dp-text:           #f3e8ff;
  --dp-text-2:         #b794d6;
  --dp-text-muted:     #6b5b8f;
  --dp-text-zh:        #ffd54f;
  --dp-quick:          #d32f2f;
  --dp-quick-glow:     rgba(211,47,47,0.35);
  --dp-ai-1:           #fbc02d;
  --dp-ai-2:           #f57c00;
  --dp-ai-glow:        rgba(251,192,45,0.40);
  --dp-analyze-1:      #4fc3f7;
  --dp-analyze-2:      #7e57c2;
  --dp-analyze-glow:   rgba(126,87,194,0.35);
  --dp-shadow-card:    0 1px 2px rgba(0,0,0,0.20), 0 8px 16px rgba(0,0,0,0.30), 0 24px 48px rgba(0,0,0,0.25);
  --dp-ease:           cubic-bezier(0.4,0,0.2,1);
  --dp-radius:         14px;
  --dp-radius-pill:    24px;
  --dp-duration:       280ms;
}

/* ─── CONTAINER ─────────────────────────────────────────────── */
.dp-container {
  max-width: 760px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding-bottom: 24px;
}

/* ─── HEADER ─────────────────────────────────────────────────── */
.dp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 4px;
}
.dp-header h2 {
  font-size: 1.3rem;
  margin: 0 0 4px;
  color: var(--text-dark, #f0f0f0);
  font-weight: 700;
}
.dp-header p {
  font-size: 0.85rem;
  color: var(--dp-text-2);
  margin: 0;
}

/* ─── LANG ROW ───────────────────────────────────────────────── */
.dp-lang-row {
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: center;
}
.dp-lang-select {
  background: var(--dp-card-bg);
  border: 1px solid var(--dp-card-border);
  border-radius: var(--dp-radius-pill);
  color: var(--dp-text);
  padding: 8px 14px;
  font-size: 0.9rem;
  font-weight: 600;
  outline: none;
  cursor: pointer;
  transition: border-color var(--dp-duration) var(--dp-ease);
  min-width: 170px;
  backdrop-filter: blur(6px);
}
.dp-lang-select:focus {
  border-color: var(--dp-quick);
  box-shadow: 0 0 0 3px rgba(211,47,47,0.15);
}
.dp-swap-btn {
  background: var(--dp-card-bg);
  border: 1px solid var(--dp-card-border);
  border-radius: 50%;
  width: 40px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--dp-text-2);
  font-size: 1rem;
  cursor: pointer;
  transition: all var(--dp-duration) var(--dp-ease);
  flex-shrink: 0;
  backdrop-filter: blur(6px);
}
.dp-swap-btn:hover {
  color: var(--dp-text);
  border-color: var(--dp-quick);
  transform: rotate(180deg);
}

/* ─── INPUT CARD ─────────────────────────────────────────────── */
.dp-input-card {
  background: var(--dp-card-bg);
  border: 1px solid var(--dp-card-border);
  border-radius: var(--dp-radius);
  box-shadow: var(--dp-shadow-card);
  overflow: hidden;
  transition: border-color var(--dp-duration) var(--dp-ease),
              box-shadow var(--dp-duration) var(--dp-ease);
  backdrop-filter: blur(var(--dp-card-blur, 8px));
}
.dp-input-card:focus-within {
  border-color: rgba(211,47,47,0.5);
  box-shadow: 0 0 0 3px rgba(211,47,47,0.10), var(--dp-shadow-card);
}
.dp-textarea {
  width: 100%;
  min-height: 130px;
  background: transparent;
  border: none;
  color: var(--dp-text);
  font-size: 1.05rem;
  line-height: 1.7;
  resize: none;
  padding: 16px 18px 10px;
  box-sizing: border-box;
  font-family: inherit;
  outline: none;
}
.dp-textarea::placeholder {
  color: var(--dp-text-muted);
  font-style: italic;
}
.dp-input-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 14px 12px;
  border-top: 1px solid rgba(255,255,255,0.05);
}
.dp-input-btns {
  display: flex;
  gap: 4px;
}
.dp-icon-btn {
  background: none;
  border: none;
  color: var(--dp-text-muted);
  font-size: 1rem;
  cursor: pointer;
  padding: 5px 8px;
  border-radius: 8px;
  transition: color var(--dp-duration), background var(--dp-duration);
}
.dp-icon-btn:hover { color: var(--dp-text); background: rgba(255,255,255,0.08); }
.dp-icon-btn.dp-btn-danger:hover { color: #ff6b6b; background: rgba(211,47,47,0.12); }
.dp-char-count {
  font-size: 0.78rem;
  color: var(--dp-text-muted);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  transition: color 0.2s;
}
.dp-char-count.dp-warn  { color: #fbc02d; }
.dp-char-count.dp-danger { color: #ff6b6b; }
@keyframes dp-shake {
  0%,100% { transform: translateX(0); }
  20%,60% { transform: translateX(-4px); }
  40%,80% { transform: translateX(4px); }
}
.dp-char-count.dp-shake { animation: dp-shake 0.4s ease; }

/* ─── ACTION CHIPS ───────────────────────────────────────────── */
.dp-action-row {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 10px;
}
.dp-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 14px 10px;
  border: 1.5px solid transparent;
  border-radius: var(--dp-radius);
  cursor: pointer;
  font-family: inherit;
  transition: all var(--dp-duration) var(--dp-ease);
  box-shadow: var(--dp-shadow-card);
  position: relative;
  overflow: hidden;
  background: var(--dp-card-bg);
  color: var(--dp-text-2);
  backdrop-filter: blur(6px);
}
.dp-chip i { font-size: 1.2rem; transition: transform 0.3s; }
.dp-chip:hover i { transform: scale(1.15); }
.dp-chip-label { font-size: 0.9rem; font-weight: 700; line-height: 1; }
.dp-chip-sub   { font-size: 0.72rem; opacity: 0.65; }
.dp-chip-vip {
  font-size: 0.62rem;
  background: linear-gradient(90deg,#fbc02d,#f57c00);
  color: #fff;
  border-radius: 8px;
  padding: 1px 6px;
  font-weight: 700;
  letter-spacing: 0.03em;
}

/* Quick — Đỏ */
.dp-chip--quick:hover, .dp-chip--quick.active {
  background: linear-gradient(145deg, rgba(211,47,47,0.22), rgba(183,28,28,0.15));
  border-color: var(--dp-quick);
  color: #ff8a80;
  box-shadow: 0 0 18px var(--dp-quick-glow), var(--dp-shadow-card);
}
.dp-chip--quick.active { color: #ffcdd2; }

/* AI — Vàng kim */
.dp-chip--ai:hover, .dp-chip--ai.active {
  background: linear-gradient(145deg, rgba(251,192,45,0.18), rgba(245,124,0,0.12));
  border-color: var(--dp-ai-1);
  color: #ffe082;
  box-shadow: 0 0 18px var(--dp-ai-glow), var(--dp-shadow-card);
}
.dp-chip--ai.active { color: #fff8e1; }

/* Phân Tích — Xanh ngọc→tím */
.dp-chip--analyze:hover, .dp-chip--analyze.active {
  background: linear-gradient(145deg, rgba(79,195,247,0.15), rgba(126,87,194,0.12));
  border-color: var(--dp-analyze-1);
  color: #b3e5fc;
  box-shadow: 0 0 18px var(--dp-analyze-glow), var(--dp-shadow-card);
}
.dp-chip--analyze.active { color: #e1f5fe; }

/* Glow pulse khi active */
@keyframes dp-glow-pulse {
  0%,100% { box-shadow: 0 0 14px var(--dp-chip-glow, rgba(211,47,47,0.3)), var(--dp-shadow-card); }
  50%      { box-shadow: 0 0 28px var(--dp-chip-glow, rgba(211,47,47,0.55)), var(--dp-shadow-card); }
}
.dp-chip--quick.active  { --dp-chip-glow: var(--dp-quick-glow);   animation: dp-glow-pulse 2s infinite; }
.dp-chip--ai.active     { --dp-chip-glow: var(--dp-ai-glow);      animation: dp-glow-pulse 2s infinite; }
.dp-chip--analyze.active{ --dp-chip-glow: var(--dp-analyze-glow); animation: dp-glow-pulse 2s infinite; }

/* ─── OUTPUT CARD ────────────────────────────────────────────── */
@keyframes dp-slide-in {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dp-output-card {
  background: var(--dp-card-bg);
  border: 1px solid var(--dp-card-border);
  border-radius: var(--dp-radius);
  box-shadow: var(--dp-shadow-card);
  padding: 20px;
  animation: dp-slide-in var(--dp-duration) var(--dp-ease);
  backdrop-filter: blur(8px);
  min-height: 80px;
}
.dp-output-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 20px;
  color: var(--dp-text-muted);
  text-align: center;
}
.dp-output-placeholder p { margin: 0; font-size: 0.95rem; }

/* Spinner */
.dp-loading {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 30px 0;
  color: var(--dp-text-2);
  font-size: 0.95rem;
}
@keyframes dp-spin { to { transform: rotate(360deg); } }
.dp-spinner {
  width: 22px;
  height: 22px;
  border: 2.5px solid rgba(255,255,255,0.12);
  border-top-color: var(--dp-quick);
  border-radius: 50%;
  animation: dp-spin 0.8s linear infinite;
}

/* ─── TRANSLATE OUTPUT ───────────────────────────────────────── */
.dp-out-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.dp-out-label {
  font-size: 0.75rem;
  color: var(--dp-text-muted);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.dp-out-text {
  font-size: 1.15rem;
  line-height: 1.8;
  color: var(--dp-text);
  font-weight: 500;
  margin-bottom: 10px;
}
.dp-out-pinyin {
  background: rgba(79,195,247,0.08);
  border: 1px solid rgba(79,195,247,0.18);
  color: #ce93d8;
  padding: 7px 12px;
  border-radius: 8px;
  font-family: 'Poppins', sans-serif;
  font-style: italic;
  font-size: 0.92rem;
  margin-bottom: 12px;
  line-height: 1.6;
  transition: opacity 0.3s;
}
.dp-hide-pinyin .dp-out-pinyin { display: none; }
.dp-out-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.dp-out-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  color: var(--dp-text-2);
  font-size: 0.8rem;
  font-weight: 600;
  padding: 5px 12px;
  cursor: pointer;
  transition: all 0.2s;
  font-family: inherit;
}
.dp-out-btn:hover {
  background: rgba(255,255,255,0.1);
  color: var(--dp-text);
}
.dp-out-btn-pinyin { margin-left: auto; }
.dp-out-btn-pinyin.active {
  background: rgba(126,87,194,0.15);
  border-color: rgba(126,87,194,0.4);
  color: #ce93d8;
}

/* Fallback warning */
.dp-fallback-banner {
  background: linear-gradient(135deg, rgba(255,248,225,0.08), rgba(255,243,224,0.06));
  border: 1px solid rgba(255,204,2,0.25);
  border-radius: 10px;
  padding: 10px 14px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 0.88rem;
  color: #ffcc02;
}

/* VIP lock */
.dp-vip-lock {
  text-align: center;
  padding: 20px;
  background: rgba(255,248,225,0.04);
  border: 2px dashed rgba(251,192,45,0.3);
  border-radius: 12px;
}
.dp-vip-lock h3 { color: var(--dp-ai-1); margin: 10px 0 8px; }
.dp-vip-lock p  { color: var(--dp-text-2); font-size: 0.92rem; margin: 0 0 16px; }

/* ─── CROSS-FLOW CHIP ────────────────────────────────────────── */
@keyframes dp-crossflow-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.dp-crossflow-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 14px;
  padding: 7px 16px;
  border-radius: var(--dp-radius-pill);
  font-size: 0.84rem;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid;
  font-family: inherit;
  transition: all 0.22s;
  animation: dp-crossflow-in 0.4s var(--dp-ease) 0.5s both;
}
.dp-crossflow-chip--analyze {
  background: rgba(79,195,247,0.10);
  border-color: rgba(79,195,247,0.35);
  color: #4fc3f7;
}
.dp-crossflow-chip--analyze:hover {
  background: rgba(79,195,247,0.20);
  box-shadow: 0 0 14px rgba(79,195,247,0.25);
}
.dp-crossflow-chip--translate {
  background: rgba(211,47,47,0.10);
  border-color: rgba(211,47,47,0.35);
  color: #ff8a80;
}
.dp-crossflow-chip--translate:hover {
  background: rgba(211,47,47,0.20);
  box-shadow: 0 0 14px var(--dp-quick-glow);
}

/* ─── ANALYZE OUTPUT — TOKENS ────────────────────────────────── */
.dp-tokens {
  line-height: 2.6;
  word-break: break-word;
  margin-bottom: 12px;
}
.dp-token {
  display: inline;
  font-family: 'KaiTi', 'STKaiti', 'Noto Serif SC', serif;
  font-size: 1.35rem;
  border-radius: 4px;
  cursor: default;
  transition: background 0.15s;
}
@keyframes dp-token-in {
  from { opacity: 0; transform: scale(0.85); }
  to   { opacity: 1; transform: scale(1); }
}
.dp-token--word {
  color: rgba(255,255,255,0.5);
  cursor: pointer;
  padding: 1px 3px;
  margin: 0 1px;
}
.dp-token--word:hover { background: rgba(255,255,255,0.08); border-radius: 4px; }

/* Màu theo cấp độ HSK */
.dp-token--hsk1 { color: #4CAF50; }
.dp-token--hsk2 { color: #8BC34A; }
.dp-token--hsk3 { color: #FFC107; }
.dp-token--hsk4 { color: #FF9800; }
.dp-token--hsk5 { color: #FF5722; }
.dp-token--hsk6 { color: #ef5350; }
.dp-token--hsk789 { color: #ce93d8; }
.dp-token--hskx { color: rgba(255,255,255,0.4); }

.dp-token--hsk1:hover   { background: rgba(76,175,80,0.18); }
.dp-token--hsk2:hover   { background: rgba(139,195,74,0.18); }
.dp-token--hsk3:hover   { background: rgba(255,193,7,0.18); }
.dp-token--hsk4:hover   { background: rgba(255,152,0,0.18); }
.dp-token--hsk5:hover   { background: rgba(255,87,34,0.18); }
.dp-token--hsk6:hover   { background: rgba(239,83,80,0.18); }
.dp-token--hsk789:hover { background: rgba(206,147,216,0.18); }
.dp-token--hskx:hover   { background: rgba(255,255,255,0.07); }

.dp-token--unknown { color: #ffe082; opacity: 0.8; }
.dp-token--punct   { color: var(--dp-text-muted); font-size: 1.1rem; font-family: inherit; }

/* Hover tooltip (lightweight) */
.dp-hover-tooltip {
  position: fixed;
  background: #000;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 10px;
  padding: 9px 13px;
  font-size: 0.9rem;
  pointer-events: none;
  z-index: 9990;
  max-width: 260px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.7);
  transform: translate(-50%, -100%);
  margin-top: -8px;
  display: none;
}
.dp-hover-tooltip .tt-pinyin-main {
  color: #ce93d8;
  display: block;
  font-size: 1.05rem;
  margin-bottom: 4px;
}
.dp-hover-tooltip .tt-vi       { color: #4fc3f7; font-weight: 600; font-size: 0.9rem; margin-top: 3px; display: block; }
.dp-hover-tooltip .tt-vi-muted { opacity: 0.5; font-size: 0.82rem; }
.dp-hover-tooltip .tt-hv       { color: #aaa; font-size: 0.78rem; }

/* Multi-reading (đa âm) trong hover tooltip */
.tt-pinyins {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 6px;
  margin-bottom: 4px;
}
.tt-py-item {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  color: #ce93d8;
  font-size: 0.95rem;
  font-weight: 700;
}
.tt-sep { color: rgba(255,255,255,0.2); font-size: 0.8rem; }
.tt-hsk-sm { font-size: 0.62rem !important; padding: 1px 4px !important; }
.tt-multi-hint {
  font-size: 0.74rem;
  color: #ffb74d;
  margin-top: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Badge HSK trong hover tooltip */
.dp-hover-tooltip .tt-hsk {
  display: inline-block;
  border-radius: 6px;
  padding: 1px 7px;
  font-size: 0.72rem;
  font-weight: 700;
  margin-top: 3px;
}
/* Màu badge HSK — đồng bộ với token */
.tt-hsk--1   { background: rgba(76,175,80,0.2);   color: #4CAF50; }
.tt-hsk--2   { background: rgba(139,195,74,0.2);  color: #8BC34A; }
.tt-hsk--3   { background: rgba(255,193,7,0.2);   color: #FFC107; }
.tt-hsk--4   { background: rgba(255,152,0,0.2);   color: #FF9800; }
.tt-hsk--5   { background: rgba(255,87,34,0.2);   color: #FF5722; }
.tt-hsk--6   { background: rgba(239,83,80,0.2);   color: #ef5350; }
.tt-hsk--789 { background: rgba(206,147,216,0.2); color: #ce93d8; }
.tt-hsk--x   { background: rgba(255,255,255,0.07); color: #aaa; }

/* Stats bar */
.dp-analyze-stats {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  font-size: 0.82rem;
  color: var(--dp-text-2);
  background: rgba(76,175,80,0.06);
  border: 1px solid rgba(76,175,80,0.12);
  border-radius: 8px;
  padding: 8px 14px;
}

/* ─── CLICK POPUP — layout multi-reading ────────────────────── */
#dp-token-popup .dp-popup-header {
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.dp-popup-readings {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  padding-top: 2px;
}
.dp-popup-py-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.dp-popup-multi-note {
  padding: 5px 12px 3px;
  font-size: 0.74rem;
  color: #ffb74d;
  display: flex;
  align-items: center;
  gap: 5px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.dp-popup-brief {
  padding: 6px 12px 4px;
  font-size: 0.88rem;
  color: #4fc3f7;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

/* ─── TOKEN POPUP (click) ────────────────────────────────────── */
@keyframes dp-popup-in {
  from { opacity: 0; transform: translate(-50%,6px) scale(0.94); }
  to   { opacity: 1; transform: translate(-50%,0) scale(1); }
}
#dp-token-popup {
  position: fixed;
  background: #000;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.8);
  z-index: 10500;
  min-width: 190px;
  overflow: hidden;
  display: none;
  animation: dp-popup-in 0.2s var(--dp-ease) both;
  transform: translateX(-50%);
}
.dp-popup-header {
  padding: 8px 12px 7px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.dp-popup-hanzi  { font-family: 'KaiTi','Noto Serif SC',serif; font-size: 1.5rem; color: var(--dp-text-zh); font-weight: 700; flex-shrink: 0; }
.dp-popup-pinyin { font-size: 0.9rem; color: #ce93d8; font-style: italic; font-weight: 600; }
.dp-popup-action {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  font-size: 0.85rem;
  color: var(--dp-text-2);
  cursor: pointer;
  transition: background 0.15s;
  border: none;
  background: none;
  width: 100%;
  text-align: left;
  font-family: inherit;
}
.dp-popup-action:hover { background: rgba(255,255,255,0.06); color: var(--dp-text); }
.dp-popup-action i { width: 18px; text-align: center; }

/* ─── HISTORY CARD ───────────────────────────────────────────── */
.dp-history-card {
  background: var(--dp-card-bg);
  border: 1px solid var(--dp-card-border);
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-card);
  backdrop-filter: blur(6px);
}
.dp-history-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 16px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  flex-wrap: wrap;
  gap: 8px;
}
.dp-history-header h4 {
  margin: 0;
  font-size: 0.9rem;
  color: var(--dp-text-2);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 7px;
}
.dp-history-tools {
  display: flex;
  gap: 6px;
  align-items: center;
}
.dp-history-search {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 20px;
  color: var(--dp-text);
  padding: 4px 12px;
  font-size: 0.8rem;
  width: 150px;
  outline: none;
  font-family: inherit;
  transition: border-color 0.2s, width 0.3s;
}
.dp-history-search:focus {
  border-color: var(--dp-quick);
  width: 200px;
}
.dp-history-search::placeholder { color: var(--dp-text-muted); }
.dp-history-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-height: 220px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: rgba(255,255,255,0.1) transparent;
}
.dp-history-item {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  padding: 10px 14px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  transition: background 0.15s;
}
.dp-history-item:last-child { border-bottom: none; }
.dp-history-item:hover { background: rgba(255,255,255,0.04); }
.dp-history-cell {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.dp-history-cell:last-child { border-left: 1px solid rgba(255,255,255,0.05); padding-left: 10px; }
.dp-history-text {
  flex: 1;
  min-width: 0;
  cursor: pointer;
}
.dp-history-src  { font-size: 0.85rem; color: var(--dp-text); font-weight: 500; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dp-history-time { font-size: 0.7rem; color: var(--dp-text-muted); margin-top: 2px; }
.dp-history-res  { font-size: 0.85rem; color: var(--dp-text-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.dp-history-btns { display: flex; gap: 2px; flex-shrink: 0; }
.dp-history-empty {
  text-align: center;
  padding: 20px;
  color: var(--dp-text-muted);
  font-size: 0.85rem;
  font-style: italic;
}
.dp-show-more-btn {
  width: 100%;
  background: none;
  border: none;
  border-top: 1px solid rgba(255,255,255,0.05);
  color: var(--dp-text-muted);
  padding: 8px;
  font-size: 0.8rem;
  cursor: pointer;
  font-family: inherit;
  transition: color 0.2s, background 0.2s;
}
.dp-show-more-btn:hover { background: rgba(255,255,255,0.04); color: var(--dp-text-2); }

/* ─── HSK ACCORDION ──────────────────────────────────────────── */
.dp-hsk-accordion {
  background: var(--dp-card-bg);
  border: 1px solid var(--dp-card-border);
  border-radius: var(--dp-radius);
  overflow: hidden;
  box-shadow: var(--dp-shadow-card);
  backdrop-filter: blur(6px);
}
.dp-hsk-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 13px 16px;
  background: none;
  border: none;
  color: var(--dp-text-2);
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
  font-family: inherit;
  transition: color 0.2s, background 0.2s;
  gap: 10px;
}
.dp-hsk-toggle:hover { color: var(--dp-text); background: rgba(255,255,255,0.03); }
.dp-hsk-arrow {
  font-size: 0.8rem;
  transition: transform var(--dp-duration) var(--dp-ease);
  flex-shrink: 0;
}
.dp-hsk-accordion.open .dp-hsk-arrow { transform: rotate(180deg); }
.dp-hsk-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s var(--dp-ease), padding 0.3s;
  padding: 0 16px;
}
.dp-hsk-accordion.open .dp-hsk-body {
  max-height: 800px;
  padding: 0 16px 16px;
}

/* HSK progress cards trong accordion — override một chút cho dark bg */
.dp-hsk-body .hsk-prog-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
}
.dp-hsk-body .hsk-prog-bar-bg { background: rgba(255,255,255,0.1); }
.dp-hsk-body .hsk-prog-stats  { color: var(--dp-text-2); }
.dp-hsk-body .hsk-prog-level  { font-size: 0.8rem; }

/* HSK bar live-update animation */
@keyframes dp-bar-update {
  0%  { transform: scaleX(1.05); }
  50% { transform: scaleX(0.98); }
  100%{ transform: scaleX(1); }
}
.dp-hsk-bar-updating { animation: dp-bar-update 0.6s ease-out; transform-origin: left; }

/* ─── RESPONSIVE ─────────────────────────────────────────────── */
@media (max-width: 600px) {
  .dp-lang-row { gap: 6px; }
  .dp-lang-select { min-width: 120px; font-size: 0.82rem; padding: 7px 10px; }
  .dp-action-row { gap: 8px; }
  .dp-chip { padding: 11px 6px; }
  .dp-chip-label { font-size: 0.82rem; }
  .dp-history-item { grid-template-columns: 1fr; }
  .dp-history-cell:last-child { border-left: none; padding-left: 0; border-top: 1px solid rgba(255,255,255,0.05); padding-top: 6px; margin-top: 4px; }
  .dp-history-search { width: 120px; }
  .dp-history-search:focus { width: 150px; }
  .dp-tokens { line-height: 2.8; }
  .dp-token { font-size: 1.2rem; }
}
@media (max-width: 400px) {
  .dp-action-row { grid-template-columns: repeat(3,1fr); gap: 6px; }
  .dp-chip i { font-size: 1rem; }
  .dp-chip-sub, .dp-chip-vip { display: none; }
}

/* ─── CLEAR HISTORY MODAL (reuse) ────────────────────────────── */
#dp-clear-hist-modal {
  display: none;
  position: fixed;
  z-index: var(--z-modal-high, 99999); /* v13.28 */
  left: 0; top: 0;
  width: 100%; height: 100%;
  justify-content: center;
  align-items: center;
  background: rgba(0,0,0,0.6);
}
#dp-clear-hist-modal .dp-modal-box {
  background: #1e1530;
  border: 1px solid rgba(255,255,255,0.12);
  max-width: 380px;
  width: 90%;
  border-radius: 18px;
  padding: 28px 24px;
  text-align: center;
}
#dp-clear-hist-modal h3 { color: var(--dp-text); margin: 12px 0 10px; }
#dp-clear-hist-modal p  { color: var(--dp-text-2); margin: 0 0 22px; font-size: 0.95rem; }
.dp-modal-actions { display: flex; gap: 10px; justify-content: center; }

/* ─── HELP BUTTON ────────────────────────────────────────────── */
.dp-help-btn {
  background: rgba(79,195,247,0.10);
  border: 1px solid rgba(79,195,247,0.25);
  color: var(--dp-analyze-1);
  border-radius: 50%;
  width: 34px;
  height: 34px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  cursor: pointer;
  flex-shrink: 0;
  transition: all 0.2s;
  font-family: inherit;
}
.dp-help-btn:hover {
  background: rgba(79,195,247,0.20);
  box-shadow: 0 0 10px rgba(79,195,247,0.3);
  transform: rotate(10deg);
}

/* ─── HELP WRAP (anchor for absolute popover) — v13.11 ─────────── */
.dp-help-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  z-index: 9998;
}

/* ─── HELP POPOVER — popup nhỏ floating, không chiếm chỗ layout ── */
@keyframes dp-help-in {
  from { opacity: 0; transform: translateY(-8px) scale(0.96); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}
.dp-help-popover {
  position: absolute;
  top: calc(100% + 14px);
  right: 0;
  width: 420px;
  max-width: min(420px, 92vw);
  background-color: #0a0a14;
  background-image: linear-gradient(135deg, #0a0a14 0%, #14141e 50%, #0a0a14 100%);
  border: 1px solid rgba(79,195,247,0.35);
  border-radius: var(--dp-radius);
  padding: 18px 20px 16px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.06) inset,
    0 -2px 0 rgba(0,0,0,0.4) inset,
    0 18px 40px rgba(0,0,0,0.7);
  animation: dp-help-in 0.22s cubic-bezier(0.34, 1.56, 0.64, 1) both;
  z-index: 9999;
}
.dp-help-arrow {
  position: absolute;
  top: -8px;
  right: 18px;
  width: 16px;
  height: 16px;
  background: #0a0a14;
  border-top: 1px solid rgba(79,195,247,0.35);
  border-left: 1px solid rgba(79,195,247,0.35);
  transform: rotate(45deg);
  z-index: -1;
}
@media (max-width: 768px) {
  .dp-help-popover {
    width: min(340px, 92vw);
    right: -10px;
    padding: 14px 16px 12px;
  }
  .dp-help-arrow { right: 26px; }
}
.dp-help-popover h4 {
  margin: 0 0 14px;
  font-size: 0.95rem;
  color: var(--dp-text);
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
}
.dp-help-close {
  position: absolute;
  top: 12px; right: 14px;
  color: var(--dp-text-muted);
  cursor: pointer;
  font-size: 0.9rem;
  padding: 4px 6px;
  border-radius: 6px;
  transition: color 0.15s, background 0.15s;
}
.dp-help-close:hover { color: var(--dp-text); background: rgba(255,255,255,0.07); }

.dp-help-items { display: flex; flex-direction: column; gap: 12px; }
.dp-help-item {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid transparent;
}
.dp-help-item--quick  { background: rgba(211,47,47,0.07); border-color: rgba(211,47,47,0.15); }
.dp-help-item--ai     { background: rgba(251,192,45,0.07); border-color: rgba(251,192,45,0.15); }
.dp-help-item--analyze{ background: rgba(79,195,247,0.07); border-color: rgba(79,195,247,0.15); }
.dp-help-item--flow   { background: rgba(126,87,194,0.07); border-color: rgba(126,87,194,0.15); }

.dp-help-icon {
  width: 28px; height: 28px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem;
  flex-shrink: 0;
  margin-top: 1px;
}
.dp-help-item--quick   .dp-help-icon { background: rgba(211,47,47,0.2); color: #ff8a80; }
.dp-help-item--ai      .dp-help-icon { background: rgba(251,192,45,0.2); color: #ffe082; }
.dp-help-item--analyze .dp-help-icon { background: rgba(79,195,247,0.2); color: #4fc3f7; }
.dp-help-item--flow    .dp-help-icon { background: rgba(126,87,194,0.2); color: #ce93d8; }

.dp-help-item strong { font-size: 0.88rem; color: var(--dp-text); display: block; margin-bottom: 3px; }
.dp-help-item p { font-size: 0.8rem; color: var(--dp-text-2); margin: 0; line-height: 1.6; }

.dp-help-tag {
  display: inline-block;
  font-size: 0.65rem;
  padding: 1px 7px;
  border-radius: 8px;
  font-weight: 700;
  margin-left: 5px;
  background: rgba(76,175,80,0.2);
  color: #81c784;
  vertical-align: middle;
}
.dp-help-tag--vip {
  background: linear-gradient(90deg, rgba(251,192,45,0.25), rgba(245,124,0,0.2));
  color: #ffe082;
}

/* ─── TOKEN POPUP VISIBLE STATE ─────────────────────────────── */
#dp-token-popup.visible { display: block; }
#dp-token-popup .dp-popup-hsk {
  display: inline-block;
  border-radius: 6px;
  padding: 1px 7px;
  font-size: 0.72rem;
  font-weight: 700;
}
/* Màu badge HSK trong click popup — đồng bộ với token */
.dp-popup-hsk--1   { background: rgba(76,175,80,0.2);   color: #4CAF50; }
.dp-popup-hsk--2   { background: rgba(139,195,74,0.2);  color: #8BC34A; }
.dp-popup-hsk--3   { background: rgba(255,193,7,0.2);   color: #FFC107; }
.dp-popup-hsk--4   { background: rgba(255,152,0,0.2);   color: #FF9800; }
.dp-popup-hsk--5   { background: rgba(255,87,34,0.2);   color: #FF5722; }
.dp-popup-hsk--6   { background: rgba(239,83,80,0.2);   color: #ef5350; }
.dp-popup-hsk--789 { background: rgba(206,147,216,0.2); color: #ce93d8; }
.dp-popup-hsk--x   { background: rgba(255,255,255,0.07); color: #aaa; }

/* ─── RESULT CONTAINERS ──────────────────────────────────────── */
.dp-result-translate,
.dp-result-analyze { animation: dp-slide-in var(--dp-duration) var(--dp-ease); }

.dp-result-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  padding-bottom: 10px;
  border-bottom: 1px solid rgba(255,255,255,0.07);
}
.dp-result-btns    { display: flex; gap: 6px; align-items: center; }
.dp-result-badge   {
  font-size: 0.75rem;
  color: var(--dp-text-muted);
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
.dp-result-main {
  font-size: 1.15rem;
  line-height: 1.8;
  color: var(--dp-text);
  font-weight: 500;
  margin-bottom: 10px;
}
.dp-result-pinyin {
  background: rgba(79,195,247,0.08);
  border: 1px solid rgba(79,195,247,0.18);
  color: #ce93d8;
  padding: 7px 12px;
  border-radius: 8px;
  font-style: italic;
  font-size: 0.92rem;
  margin-bottom: 12px;
}
.dp-crossflow-wrap { margin-top: 4px; }

/* ─── ERROR STATE ────────────────────────────────────────────── */
.dp-error {
  color: #ff6b6b;
  text-align: center;
  padding: 20px;
  font-size: 0.95rem;
}

/* ─── TOAST ──────────────────────────────────────────────────── */
.dp-toast {
  position: fixed;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  background: rgba(30,21,48,0.92);
  border: 1px solid rgba(255,255,255,0.15);
  color: #f3e8ff;
  padding: 9px 22px;
  border-radius: 22px;
  font-size: 0.9rem;
  z-index: var(--z-modal-high, 99999); /* v13.28 */
  opacity: 0;
  transition: opacity 0.25s, transform 0.25s;
  pointer-events: none;
  white-space: nowrap;
}
.dp-toast.visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

/* ═══════════════════════════════════════════════════════════════
   S52 — LIGHT MODE OVERRIDES cho dich-phantich
   Yêu cầu: text đen in đậm to hơn · 3 chip màu tươi · BỎ 3D shadow.
   Scope toàn bộ dưới html[data-theme="light"] — KHÔNG leak sang dark.
   ═══════════════════════════════════════════════════════════════ */

/* Variables — tham chiếu LLC tokens cho light */
html[data-theme="light"] #tab-dich-phantich {
  --dp-card-bg:        var(--ytt-bg-card);   /* #FFFFFF */
  --dp-card-border:    var(--ytt-border-1);  /* #DDD6FE */
  --dp-text:           #1a1632;              /* đen tím đậm */
  --dp-text-2:         #3d2f6b;              /* tím đậm cho secondary */
  --dp-text-muted:     #6b5b8f;              /* muted */
  --dp-text-zh:        #92670a;              /* gold đậm cho Hán tự */
  --dp-shadow-card:    0 1px 3px rgba(124,58,237,0.08);  /* flat, gần như tắt */
  --dp-card-blur:      0px;
}

/* ─── HEADER — text đen, to, đậm ─────────────────────────────── */
html[data-theme="light"] .dp-header h2 {
  color: #1a1632;
  font-size: 1.6rem;
  font-weight: 800;
}
html[data-theme="light"] .dp-header p {
  color: #2d2150;
  font-size: 1rem;
  font-weight: 600;
}

/* ─── LANG ROW — text đen đậm ────────────────────────────────── */
/* !important để win legacy `body.dark-mode select { #222 !important }` (dict-page.css:623).
   Dark mode KHÔNG ảnh hưởng vì rule legacy chỉ active khi body.dark-mode còn class. */
html[data-theme="light"] .dp-lang-select {
  background: var(--ytt-bg-input) !important;
  border: 1px solid var(--ytt-border-1) !important;
  color: #1a1632 !important;
  font-size: 1rem;
  font-weight: 700;
  backdrop-filter: none;
}
html[data-theme="light"] .dp-lang-select:focus {
  border-color: var(--dp-quick) !important;
  box-shadow: 0 0 0 3px rgba(211,47,47,0.12);
}
html[data-theme="light"] .dp-swap-btn {
  background: var(--ytt-bg-card);
  border-color: var(--ytt-border-1);
  color: #3d2f6b;
  backdrop-filter: none;
}
html[data-theme="light"] .dp-swap-btn:hover {
  color: var(--dp-quick);
  border-color: var(--dp-quick);
}

/* ─── INPUT CARD — viền đen đậm, flat, không 3D ────────────── */
html[data-theme="light"] .dp-input-card {
  background: var(--ytt-bg-card);
  border: 2px solid #1a1632;
  box-shadow: 0 1px 3px rgba(124,58,237,0.06);
  backdrop-filter: none;
}
html[data-theme="light"] .dp-input-card:focus-within {
  border-color: #d32f2f;
  box-shadow: 0 0 0 3px rgba(211,47,47,0.12);
}
/* !important để win legacy `body.dark-mode textarea { #222 !important }` (dict-page.css:622).
   Textarea giữ background trong suốt — màu nền trắng đến từ .dp-input-card parent. */
html[data-theme="light"] .dp-textarea {
  background: transparent !important;
  color: #1a1632 !important;
  border: none !important;
  font-size: 1.1rem;
  font-weight: 600;
}
html[data-theme="light"] .dp-textarea::placeholder {
  color: #6b5b8f;
  font-weight: 500;
  font-style: italic;
}
html[data-theme="light"] .dp-input-footer {
  border-top-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-icon-btn {
  color: #3d2f6b;
}
html[data-theme="light"] .dp-icon-btn:hover {
  color: #1a1632;
  background: var(--ytt-bg-hover);
}
html[data-theme="light"] .dp-icon-btn.dp-btn-danger:hover {
  color: var(--dp-quick);
  background: rgba(211,47,47,0.10);
}
html[data-theme="light"] .dp-char-count {
  color: #3d2f6b;
  font-size: 0.88rem;
  font-weight: 700;
}

/* ─── ACTION CHIPS — gradient màu tươi luôn, KHÔNG viền, KHÔNG 3D ── */
html[data-theme="light"] .dp-chip {
  border: none;
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(124,58,237,0.10);
  backdrop-filter: none;
  animation: none;
}
html[data-theme="light"] .dp-chip-label {
  font-size: 1rem;
  font-weight: 800;
  color: inherit;
}
html[data-theme="light"] .dp-chip-sub {
  font-size: 0.82rem;
  font-weight: 700;
  color: rgba(255,255,255,0.92);
  opacity: 1;
}
html[data-theme="light"] .dp-chip i {
  color: #ffffff;
}

/* [S52 EARTHY v12.79+] 3 chips theo phong cách terracotta+petrol+blush+slate
   Quick (Dịch Nhanh) — Terracotta đậm (warm red đất, đại diện free/fast) */
html[data-theme="light"] .dp-chip--quick,
html[data-theme="light"] .dp-chip--quick:hover,
html[data-theme="light"] .dp-chip--quick.active {
  background: linear-gradient(135deg, #C4622D 0%, #b35828 100%);
  color: #ffffff;
  border: none;
  animation: none;
}
html[data-theme="light"] .dp-chip--quick:hover {
  box-shadow: 0 4px 12px rgba(196,98,45,0.35);
  filter: brightness(1.06);
}
html[data-theme="light"] .dp-chip--quick.active {
  box-shadow: 0 4px 14px rgba(196,98,45,0.45), inset 0 0 0 2px rgba(255,255,255,0.45);
}

/* AI (Dịch AI VIP) — Gold-terracotta gradient (warm amber, giữ VIP identity) */
html[data-theme="light"] .dp-chip--ai,
html[data-theme="light"] .dp-chip--ai:hover,
html[data-theme="light"] .dp-chip--ai.active {
  background: linear-gradient(135deg, #d4af37 0%, #C4622D 100%);
  color: #ffffff;
  border: none;
  animation: none;
}
html[data-theme="light"] .dp-chip--ai:hover {
  box-shadow: 0 4px 12px rgba(212,175,55,0.40);
  filter: brightness(1.06);
}
html[data-theme="light"] .dp-chip--ai.active {
  box-shadow: 0 4px 14px rgba(196,98,45,0.45), inset 0 0 0 2px rgba(255,255,255,0.50);
}
html[data-theme="light"] .dp-chip--ai .dp-chip-vip {
  background: rgba(255,255,255,0.32);
  color: #ffffff;
  font-weight: 800;
}

/* Phân Tích — Petrol gradient (cool blue đất, đại diện analyze/dissect) */
html[data-theme="light"] .dp-chip--analyze,
html[data-theme="light"] .dp-chip--analyze:hover,
html[data-theme="light"] .dp-chip--analyze.active {
  background: linear-gradient(135deg, #2E6B7A 0%, #1f4c57 100%);
  color: #ffffff;
  border: none;
  animation: none;
}
html[data-theme="light"] .dp-chip--analyze:hover {
  box-shadow: 0 4px 12px rgba(46,107,122,0.40);
  filter: brightness(1.08);
}
html[data-theme="light"] .dp-chip--analyze.active {
  box-shadow: 0 4px 14px rgba(46,107,122,0.50), inset 0 0 0 2px rgba(255,255,255,0.45);
}

/* Tắt hoàn toàn glow-pulse 3D ở light mode */
html[data-theme="light"] .dp-chip--quick.active,
html[data-theme="light"] .dp-chip--ai.active,
html[data-theme="light"] .dp-chip--analyze.active {
  animation: none !important;
}

/* ─── OUTPUT CARD — viền đen đậm, flat ──────────────────────── */
html[data-theme="light"] .dp-output-card {
  background: var(--ytt-bg-card);
  border: 2px solid #1a1632;
  box-shadow: 0 1px 3px rgba(124,58,237,0.06);
  backdrop-filter: none;
}
html[data-theme="light"] .dp-output-placeholder {
  color: #3d2f6b;
}
html[data-theme="light"] .dp-output-placeholder p {
  font-size: 1.05rem;
  font-weight: 600;
  color: #3d2f6b;
}
html[data-theme="light"] .dp-out-header {
  border-bottom-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-out-label {
  color: #3d2f6b;
  font-weight: 700;
}
html[data-theme="light"] .dp-out-text {
  color: #1a1632;
  font-weight: 600;
}
html[data-theme="light"] .dp-out-pinyin {
  background: rgba(126,87,194,0.08);
  border-color: rgba(126,87,194,0.28);
  color: #4527a0;
}
html[data-theme="light"] .dp-out-btn {
  background: var(--ytt-bg-card);
  border-color: var(--ytt-border-1);
  color: #1a1632;
  font-weight: 700;
}
html[data-theme="light"] .dp-out-btn:hover {
  background: var(--ytt-bg-hover);
  color: var(--dp-quick);
}
html[data-theme="light"] .dp-out-btn-pinyin.active {
  background: rgba(126,87,194,0.15);
  border-color: rgba(126,87,194,0.50);
  color: #4527a0;
}

/* ─── CROSSFLOW CHIP ─────────────────────────────────────────── */
html[data-theme="light"] .dp-crossflow-chip--analyze {
  background: rgba(79,195,247,0.10);
  border-color: rgba(79,195,247,0.50);
  color: #1565c0;
  font-weight: 700;
}
html[data-theme="light"] .dp-crossflow-chip--analyze:hover {
  background: rgba(79,195,247,0.18);
  box-shadow: 0 2px 8px rgba(79,195,247,0.20);
}
html[data-theme="light"] .dp-crossflow-chip--translate {
  background: rgba(211,47,47,0.10);
  border-color: rgba(211,47,47,0.50);
  color: #c62828;
  font-weight: 700;
}
html[data-theme="light"] .dp-crossflow-chip--translate:hover {
  background: rgba(211,47,47,0.18);
  box-shadow: 0 2px 8px rgba(211,47,47,0.20);
}

/* ─── ANALYZE TOKENS — chữ đen đậm trên nền sáng ─────────────── */
html[data-theme="light"] .dp-token--word {
  color: #1a1632;
  font-weight: 700;
}
html[data-theme="light"] .dp-token--word:hover {
  background: var(--ytt-bg-hover);
}
html[data-theme="light"] .dp-token--hsk1 { color: #2e7d32; }
html[data-theme="light"] .dp-token--hsk2 { color: #558b2f; }
html[data-theme="light"] .dp-token--hsk3 { color: #ef6c00; }
html[data-theme="light"] .dp-token--hsk4 { color: #e65100; }
html[data-theme="light"] .dp-token--hsk5 { color: #d84315; }
html[data-theme="light"] .dp-token--hsk6 { color: #c62828; }
html[data-theme="light"] .dp-token--hsk789 { color: #6a1b9a; }
html[data-theme="light"] .dp-token--hskx { color: #3d2f6b; }
html[data-theme="light"] .dp-token--unknown { color: #b45309; opacity: 1; }
html[data-theme="light"] .dp-token--punct { color: #3d2f6b; }

html[data-theme="light"] .dp-analyze-stats {
  background: rgba(46,125,50,0.08);
  border-color: rgba(46,125,50,0.22);
  color: #1b5e20;
  font-weight: 700;
}

/* ─── HISTORY CARD ───────────────────────────────────────────── */
html[data-theme="light"] .dp-history-card {
  background: var(--ytt-bg-card);
  border-color: var(--ytt-border-1);
  box-shadow: 0 1px 3px rgba(124,58,237,0.08);
  backdrop-filter: none;
}
html[data-theme="light"] .dp-history-header {
  border-bottom-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-history-header h4 {
  color: #1a1632;
  font-size: 1rem;
  font-weight: 800;
}
/* !important để win legacy `body.dark-mode input { #222 !important }` (dict-page.css:622). */
html[data-theme="light"] .dp-history-search {
  background: var(--ytt-bg-input) !important;
  border: 1px solid var(--ytt-border-1) !important;
  color: #1a1632 !important;
  font-weight: 600;
}
html[data-theme="light"] .dp-history-search:focus {
  border-color: var(--dp-quick) !important;
}
html[data-theme="light"] .dp-history-search::placeholder {
  color: #6b5b8f;
}
html[data-theme="light"] .dp-history-item {
  border-bottom-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-history-item:hover {
  background: var(--ytt-bg-hover);
}
html[data-theme="light"] .dp-history-cell:last-child {
  border-left-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-history-src {
  color: #1a1632;
  font-weight: 700;
}
html[data-theme="light"] .dp-history-time {
  color: #6b5b8f;
  font-weight: 600;
}
html[data-theme="light"] .dp-history-res {
  color: #3d2f6b;
  font-weight: 600;
}
html[data-theme="light"] .dp-history-empty {
  color: #6b5b8f;
  font-weight: 600;
}
html[data-theme="light"] .dp-show-more-btn {
  border-top-color: var(--ytt-border-1);
  color: #3d2f6b;
  font-weight: 700;
}
html[data-theme="light"] .dp-show-more-btn:hover {
  background: var(--ytt-bg-hover);
  color: #1a1632;
}

/* ─── HSK ACCORDION ──────────────────────────────────────────── */
html[data-theme="light"] .dp-hsk-accordion {
  background: #f3b6b6;
  border-color: #1a1632;
  box-shadow: 0 1px 3px rgba(124,58,237,0.08);
  backdrop-filter: none;
}
html[data-theme="light"] .dp-hsk-toggle {
  color: #1a1632;
  font-size: 1rem;
  font-weight: 800;
}
html[data-theme="light"] .dp-hsk-toggle:hover {
  background: rgba(255,255,255,0.18);
}

/* ─── HELP BUTTON + POPOVER ──────────────────────────────────── */
html[data-theme="light"] .dp-help-btn {
  background: rgba(79,195,247,0.12);
  border-color: rgba(79,195,247,0.45);
  color: #1565c0;
}
html[data-theme="light"] .dp-help-btn:hover {
  background: rgba(79,195,247,0.22);
  box-shadow: 0 2px 8px rgba(79,195,247,0.22);
}
html[data-theme="light"] .dp-help-popover {
  background-color: var(--ytt-bg-card);
  background-image: none;
  border-color: var(--ytt-border-1);
  box-shadow: 0 8px 24px rgba(45,30,80,0.16);
  backdrop-filter: none;
}
html[data-theme="light"] .dp-help-arrow {
  background: var(--ytt-bg-card);
  border-top-color: var(--ytt-border-1);
  border-left-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-help-popover h4 {
  color: #1a1632;
  font-size: 1.05rem;
  font-weight: 800;
}
html[data-theme="light"] .dp-help-close {
  color: #6b5b8f;
}
html[data-theme="light"] .dp-help-close:hover {
  color: #1a1632;
  background: var(--ytt-bg-hover);
}
html[data-theme="light"] .dp-help-item strong {
  color: #1a1632;
  font-size: 0.95rem;
}
html[data-theme="light"] .dp-help-item p {
  color: #3d2f6b;
  font-size: 0.88rem;
  font-weight: 500;
}
html[data-theme="light"] .dp-help-item--quick   { background: rgba(211,47,47,0.06); border-color: rgba(211,47,47,0.25); }
html[data-theme="light"] .dp-help-item--ai      { background: rgba(251,192,45,0.08); border-color: rgba(251,192,45,0.30); }
html[data-theme="light"] .dp-help-item--analyze { background: rgba(79,195,247,0.06); border-color: rgba(79,195,247,0.30); }
html[data-theme="light"] .dp-help-item--flow    { background: rgba(126,87,194,0.06); border-color: rgba(126,87,194,0.30); }
html[data-theme="light"] .dp-help-item--quick   .dp-help-icon { background: rgba(211,47,47,0.18); color: #c62828; }
html[data-theme="light"] .dp-help-item--ai      .dp-help-icon { background: rgba(251,192,45,0.22); color: #b45309; }
html[data-theme="light"] .dp-help-item--analyze .dp-help-icon { background: rgba(79,195,247,0.20); color: #1565c0; }
html[data-theme="light"] .dp-help-item--flow    .dp-help-icon { background: rgba(126,87,194,0.18); color: #6a1b9a; }
html[data-theme="light"] .dp-help-tag {
  background: rgba(46,125,50,0.18);
  color: #2e7d32;
  font-weight: 700;
}
html[data-theme="light"] .dp-help-tag--vip {
  background: linear-gradient(90deg, #f57c00, #d84315);
  color: #ffffff;
}

/* ─── RUN BUTTON inline #dp-run-btn — earthy shadow ──── */
/* JS đặt background gradient inline theo method active.
   Shadow override per-method earthy tone, không đụng background. */
html[data-theme="light"] #dp-run-btn {
  box-shadow: 0 3px 10px rgba(196,98,45,0.25) !important;
  font-weight: 800 !important;
}
html[data-theme="light"] #dp-run-btn[data-method="quick"]   { box-shadow: 0 3px 12px rgba(196,98,45,0.35) !important; }
html[data-theme="light"] #dp-run-btn[data-method="ai"]      { box-shadow: 0 3px 12px rgba(212,175,55,0.35) !important; }
html[data-theme="light"] #dp-run-btn[data-method="analyze"] { box-shadow: 0 3px 12px rgba(46,107,122,0.40) !important; }

/* ─── CLEAR HIST MODAL ───────────────────────────────────────── */
html[data-theme="light"] #dp-clear-hist-modal {
  background: rgba(45,30,80,0.40);
}
html[data-theme="light"] #dp-clear-hist-modal .dp-modal-box {
  background: var(--ytt-bg-card);
  border-color: var(--ytt-border-1);
}
html[data-theme="light"] #dp-clear-hist-modal h3 {
  color: #1a1632;
  font-weight: 800;
}
html[data-theme="light"] #dp-clear-hist-modal p {
  color: #3d2f6b;
  font-weight: 600;
}

/* ─── RESULT TOOLBAR + MAIN ──────────────────────────────────── */
html[data-theme="light"] .dp-result-toolbar {
  border-bottom-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-result-badge {
  color: #3d2f6b;
  font-weight: 700;
}
html[data-theme="light"] .dp-result-main {
  color: #1a1632;
  font-weight: 600;
}
html[data-theme="light"] .dp-result-pinyin {
  background: rgba(126,87,194,0.08);
  border-color: rgba(126,87,194,0.28);
  color: #4527a0;
}

/* ─── TOOLTIPS / POPUPS — chuyển sang nền sáng cho readability ── */
html[data-theme="light"] .dp-hover-tooltip {
  background: #FFFFFF;
  border-color: var(--ytt-border-1);
  color: #1a1632;
  box-shadow: 0 8px 24px rgba(45,30,80,0.20);
}
html[data-theme="light"] .dp-hover-tooltip .tt-pinyin-main {
  color: #4527a0;
}
html[data-theme="light"] .dp-hover-tooltip .tt-vi {
  color: #1565c0;
}
html[data-theme="light"] .dp-hover-tooltip .tt-vi-muted {
  color: #6b5b8f;
}
html[data-theme="light"] .dp-hover-tooltip .tt-hv {
  color: #6b5b8f;
}
html[data-theme="light"] #dp-token-popup {
  background: #FFFFFF;
  border-color: var(--ytt-border-1);
  box-shadow: 0 8px 24px rgba(45,30,80,0.20);
}
html[data-theme="light"] .dp-popup-header {
  border-bottom-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-popup-hanzi {
  color: #92670a;
}
html[data-theme="light"] .dp-popup-pinyin {
  color: #4527a0;
}
html[data-theme="light"] .dp-popup-action {
  color: #1a1632;
  font-weight: 600;
}
html[data-theme="light"] .dp-popup-action:hover {
  background: var(--ytt-bg-hover);
  color: #1a1632;
}
html[data-theme="light"] .dp-popup-multi-note {
  color: #b45309;
  border-bottom-color: var(--ytt-border-1);
}
html[data-theme="light"] .dp-popup-brief {
  color: #1565c0;
  border-bottom-color: var(--ytt-border-1);
}

/* ─── TOAST ──────────────────────────────────────────────────── */
html[data-theme="light"] .dp-toast {
  background: rgba(255,255,255,0.96);
  border-color: var(--ytt-border-1);
  color: #1a1632;
  font-weight: 700;
  box-shadow: 0 8px 24px rgba(45,30,80,0.18);
}

/* ─── FALLBACK BANNER + VIP LOCK — text đậm hơn ──────────────── */
html[data-theme="light"] .dp-fallback-banner {
  background: rgba(251,192,45,0.10);
  border-color: rgba(251,192,45,0.45);
  color: #b45309;
  font-weight: 700;
}
html[data-theme="light"] .dp-vip-lock {
  background: rgba(251,192,45,0.06);
  border-color: rgba(251,192,45,0.45);
}
html[data-theme="light"] .dp-vip-lock h3 {
  color: #b45309;
  font-weight: 800;
}
html[data-theme="light"] .dp-vip-lock p {
  color: #3d2f6b;
  font-weight: 600;
}

/* ─── HSK PROGRESS CARDS — viền đậm, chữ to bold, progress bar visible ── */
/* Override `body.dark-mode .hsk-prog-bar-bg { #444 }` legacy (dict-page.css:1380)
   chỉ active khi body.dark-mode → light mode không động tới legacy rule. */
html[data-theme="light"] .dp-hsk-body .hsk-prog-card {
  background: #FFFFFF;
  border: 2px solid #1a1632;
  padding: 14px;
  border-radius: 12px;
  box-shadow: 0 1px 3px rgba(124,58,237,0.06);
}
html[data-theme="light"] .dp-hsk-body .hsk-prog-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(124,58,237,0.15);
  border-color: #2d2150;
}
html[data-theme="light"] .dp-hsk-body .hsk-prog-level {
  font-size: 1.1rem;
  font-weight: 900;
  margin-bottom: 10px;
}
html[data-theme="light"] .dp-hsk-body .hsk-prog-stats {
  font-size: 0.95rem;
  font-weight: 700;
  color: #1a1632;
  margin-top: 8px;
}
html[data-theme="light"] .dp-hsk-body .hsk-prog-stats span {
  font-weight: 900;
  color: #1a1632;
}
/* Bar track — đậm hơn để visible khi fill 0% */
html[data-theme="light"] .dp-hsk-body .hsk-prog-bar-bg {
  background: #DDD6FE;
  height: 8px;
  border: 1px solid #C4BEDD;
}
html[data-theme="light"] .dp-hsk-body .hsk-prog-bar-bg.big {
  height: 14px;
  background: #DDD6FE;
  border: 1px solid #C4BEDD;
  margin-top: 10px;
}

/* Khung "Tổng" — viền đậm + text bold to */
html[data-theme="light"] .dp-hsk-body .hsk-prog-total {
  background: #FFFFFF;
  border: 2px solid #1a1632;
  border-radius: 12px;
  padding: 16px 18px;
  color: #1a1632;
  font-size: 1.05rem;
  font-weight: 800;
  box-shadow: 0 1px 3px rgba(124,58,237,0.06);
}
/* Hint "Click vào từng cấp..." — đậm hơn cho dễ đọc */
html[data-theme="light"] .dp-hsk-body .hsk-prog-total > div {
  color: #3d2f6b !important;
  font-size: 0.85rem !important;
  font-weight: 600 !important;
  margin-top: 8px !important;
}
