.loading,.empty-msg{color:#a0a0b0;padding:2rem;text-align:center}.vocab-add-row{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem;align-items:stretch}.vocab-add-row-inputs{display:flex;gap:.5rem;align-items:stretch}.vocab-add-check-toggle{display:inline-flex;align-items:center;gap:.4rem;font-size:var(--font-size-sm);color:var(--text-muted);cursor:pointer;user-select:none;align-self:flex-start}.vocab-add-check-toggle input[type=checkbox]{accent-color:var(--accent-jade);cursor:pointer}.vocab-add-duplicate{margin:0;font-size:var(--font-size-sm);color:var(--accent-sun)}.vocab-search-input{flex:1;min-width:0;max-width:360px;padding:.4rem .75rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);font:inherit;font-size:var(--font-size-sm);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.vocab-search-input:focus,.vocab-search-input:focus-visible{outline:none;border-color:var(--accent-jade);box-shadow:var(--ring-focus)}.vocab-search-input::placeholder{color:var(--text-muted);opacity:.7}.vocab-add-input{flex:1;min-width:0;padding:.55rem .75rem;border:1px solid var(--border-card);border-radius:6px;font-size:.95rem;background:var(--surface-card);transition:border-color .15s}.vocab-add-input:focus{outline:none;border-color:var(--accent-jade)}.vocab-add-input:disabled{background:var(--surface-muted);color:var(--text-muted);cursor:not-allowed;opacity:.7}.vocab-add-input-primary{flex:2}.vocab-add-input-secondary{flex:1}.vocab-add-btn{padding:.55rem 1.25rem;border:none;background:var(--accent-jade);color:#fff;border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .15s}.vocab-add-btn:hover:not(:disabled){background:var(--accent-jade-hover)}.vocab-add-btn:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.vocab-add-row-inputs{flex-wrap:wrap}.vocab-add-input,.vocab-add-btn{flex-basis:100%}}.speed-search-chip{position:fixed;right:var(--spacing-lg);bottom:var(--spacing-lg);z-index:30;display:inline-flex;align-items:baseline;gap:.5rem;padding:.55rem .85rem;background:var(--surface-card);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);box-shadow:var(--shadow-md, 0 4px 14px rgba(0, 0, 0, .15));font-size:var(--font-size-sm);pointer-events:none}.speed-search-chip .speed-search-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.speed-search-chip .speed-search-query{font-family:var(--font-mono, monospace);font-weight:var(--font-weight-medium);color:var(--accent-jade)}.speed-search-chip .speed-search-hint{color:var(--text-muted);font-size:var(--font-size-xs)}.speed-search-hit{background:var(--accent-jade-soft);color:inherit;border-radius:2px;padding:0 1px}.vocab-validate-modal .vocab-validate-entry{margin:0 0 .75rem;font-size:var(--font-size-lg, 1.05rem);font-weight:var(--font-weight-medium);color:var(--text-primary)}.vocab-validate-modal .vocab-validate-comments{margin:0 0 .75rem;color:var(--text-primary);font-size:var(--font-size-sm);line-height:1.5}.vocab-validate-modal .vocab-validate-suggestion{margin:0;padding:.55rem .75rem;background:var(--accent-jade-soft);border-radius:var(--radius-md);display:flex;gap:.4rem;align-items:baseline;flex-wrap:wrap}.vocab-validate-modal .vocab-validate-suggestion-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.vocab-validate-modal .vocab-validate-suggestion-text{font-weight:var(--font-weight-medium);color:var(--accent-jade)}.sort-criteria{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;flex:1;min-width:0}.sort-criterion-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.4rem .85rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);cursor:pointer;font:inherit;font-size:var(--font-size-sm);transition:background var(--transition-fast),color var(--transition-fast),border-color var(--transition-fast)}.sort-criterion-btn:hover{border-color:var(--accent-jade);color:var(--accent-jade)}.sort-criterion-btn.active{background:var(--accent-jade-soft);border-color:var(--accent-jade);color:var(--accent-jade)}.sort-criterion-btn .sort-arrow{font-size:.9em;line-height:1;min-width:.7em;text-align:center}.vocab-table tbody tr.has-mastery{background-color:hsl(calc(var(--mastery) * 120),55%,32%,.2);box-shadow:inset 3px 0 hsl(calc(var(--mastery) * 120),65%,50%)}.row-highlight{animation:row-highlight-fade 2s ease-out}@keyframes row-highlight-fade{0%{background-color:var(--accent-jade-overlay)}to{background-color:transparent}}.vocab-table tbody tr.row-duplicate{background-color:var(--accent-jade-soft);box-shadow:inset 3px 0 0 var(--accent-jade)}.phrase-gen-word{color:var(--accent-jade);font-style:italic}.phrase-gen-hint{margin:0 0 .75rem;font-size:var(--font-size-sm);color:var(--text-muted)}.phrase-gen-list{display:flex;flex-direction:column;gap:.4rem}.phrase-gen-option{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) .75rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),border-color var(--transition-fast)}.phrase-gen-option:hover{border-color:var(--accent-jade);background:var(--accent-jade-soft)}.phrase-gen-option input[type=checkbox]{accent-color:var(--accent-jade);cursor:pointer;flex-shrink:0}.phrase-gen-texts{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}.phrase-gen-translation{font-size:var(--font-size-sm);color:var(--text-muted)}.phrase-gen-option input[type=checkbox]:checked+.phrase-gen-texts .phrase-gen-phrase{color:var(--accent-jade);font-weight:var(--font-weight-medium)}.phrase-gen-option .phrase-gen-speak{opacity:.7}.phrase-gen-option:hover .phrase-gen-speak,.phrase-gen-option .phrase-gen-speak:hover,.phrase-gen-option .phrase-gen-speak.is-busy{opacity:1}.loading-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-lg);gap:var(--spacing-sm);color:var(--text-muted)}.generate-phrases-btn{color:var(--accent-sun)}.ai-generate-modal .ai-field{display:flex;flex-direction:column;gap:.4rem;margin-bottom:var(--spacing-md)}.ai-generate-modal .ai-field .toggle{align-self:flex-start}.ai-generate-modal .ai-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.ai-generate-modal .ai-input{width:100%;padding:.55rem .75rem;background:var(--surface-muted);color:var(--text-primary);border:1px solid var(--border-card);border-radius:var(--radius-md);font:inherit;font-size:var(--font-size-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast)}.ai-generate-modal .ai-input:focus{outline:none;border-color:var(--accent-jade);background:var(--surface-card);box-shadow:var(--ring-focus)}.ai-generate-modal .ai-error{margin:0;color:var(--accent-coral);font-size:var(--font-size-sm)}.vocab-frequency-btn{display:inline-flex;align-items:center;gap:.4em;white-space:nowrap}.vocab-frequency-btn svg{width:1.05em;height:1.05em}.frequency-modal{width:min(560px,94vw)}.freq-content{display:flex;flex-direction:column;gap:var(--spacing-md);min-height:0}.freq-bands{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:var(--spacing-sm)}.freq-band{text-align:center;padding:var(--spacing-sm) var(--spacing-xs);border:1px solid var(--border-card);border-radius:var(--radius-md);background:var(--surface-muted)}.freq-band-pct{font-size:var(--font-size-xl, 1.4rem);font-weight:var(--font-weight-bold);color:var(--accent-jade);line-height:1.1}.freq-band-label{font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-top:.15em}.freq-band-sub{font-size:var(--font-size-xs);color:var(--text-muted);margin-top:.1em}.freq-legend{margin:0;font-size:var(--font-size-sm);color:var(--text-muted);display:flex;align-items:center;gap:.5em;flex-wrap:wrap}.freq-legend-mastery{width:3em;height:.7em;border-radius:var(--radius-sm);flex:none;background:linear-gradient(90deg,#b23434,#b2b234,#34b234)}.freq-toolbar{display:flex;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap}.freq-toolbar-note{font-size:var(--font-size-sm);color:var(--text-muted)}.freq-list{overflow-y:auto;height:56vh;border:1px solid var(--border-card);border-radius:var(--radius-md)}.freq-list-sizer{position:relative;width:100%}.freq-list-window{position:absolute;top:0;left:0;right:0}.freq-row{height:30px;box-sizing:border-box;display:flex;align-items:center;gap:var(--spacing-sm);padding:0 var(--spacing-sm);border-bottom:1px solid var(--border-card)}.freq-row:last-child{border-bottom:none}.freq-rank{flex:none;min-width:3.2em;text-align:right;font-variant-numeric:tabular-nums;font-size:var(--font-size-sm);color:var(--text-muted)}.freq-word{color:var(--text-muted);overflow-wrap:anywhere}.freq-row.is-added .freq-word{color:var(--text-primary);font-weight:var(--font-weight-medium)}.freq-row.is-added:not(.has-mastery){box-shadow:inset 3px 0 0 var(--accent-jade)}.freq-row.has-mastery{background-color:hsl(calc(var(--mastery) * 120),55%,32%,.2);box-shadow:inset 3px 0 hsl(calc(var(--mastery) * 120),65%,50%)}
