@import"https://fonts.googleapis.com/css2?family=Heebo:wght@400;600;700&display=swap";:root{--bg: #eceef1;--panel: #ffffff;--soft: #e8ecf0;--line: #d0d6de;--text: #12161b;--muted: #667384;--want: #5b6fa8;--accent: #8f5f2b;--teal: #1f8a70;--due: #b85c2b;--adj: #8b5599}[data-theme=dark]{--bg: #0e1219;--panel: #161c27;--soft: #1d2636;--line: #2a3648;--text: #e4ebf5;--muted: #a0adc0;--accent: #c29158;--teal: #4bb89c;--due: #d4854a;--adj: #b87fc8;--want: #7b8fc4}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:Heebo,system-ui,sans-serif;line-height:1.5;height:100vh;overflow:hidden}.app{max-width:960px;margin:20px auto;background:var(--panel);border:1px solid var(--line);display:flex;flex-direction:column;height:calc(100vh - 40px);overflow:hidden}@media (max-width: 960px){.app{margin:0;height:100vh}}.head{padding:14px 20px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}.head h1{font-size:1.2rem;font-weight:700;letter-spacing:-.3px}.head-right{display:flex;align-items:center;gap:16px}.head-nav{display:flex;gap:0}.nav-link{padding:6px 12px;font-size:.82rem;font-weight:600;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;transition:color .12s}.nav-link:hover{color:var(--text)}.nav-link.active{color:var(--accent);border-bottom-color:var(--accent)}.head-btn{border:1px solid var(--line);background:var(--soft);color:var(--text);padding:5px 10px;font-family:inherit;font-size:.78rem;font-weight:600;cursor:pointer}.head-btn:hover{border-color:var(--accent)}.home-page{flex:1;overflow-y:auto}.loop{padding:28px 20px 20px;border-bottom:1px solid var(--line);text-align:center}.loop h2{font-size:1.05rem;font-weight:700;margin-bottom:6px}.loop p{color:var(--muted);font-size:.85rem;margin-bottom:16px;max-width:480px;margin-left:auto;margin-right:auto}.rings{display:flex;justify-content:center;gap:8px;flex-wrap:wrap}.ring{border:1px solid var(--line);background:var(--soft);padding:5px 14px;font-size:.8rem;font-weight:600;color:var(--muted);position:relative}.ring+.ring:before{content:"→";position:absolute;left:-13px;color:var(--line);font-weight:400}.slabs{padding:12px 20px;display:grid;gap:8px;border-bottom:1px solid var(--line)}.slab{border:1px solid var(--line);background:var(--soft);padding:14px 16px;display:flex;justify-content:space-between;align-items:center;gap:14px;cursor:pointer;transition:border-color .12s}.slab:hover{border-color:var(--accent)}.slab-body h3{font-size:.95rem;font-weight:700;margin-bottom:2px}.slab-body p{color:var(--muted);font-size:.82rem}.slab-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.slab-badge{font-size:.75rem;font-weight:600;padding:4px 10px;background:var(--panel);border:1px solid var(--line);color:var(--muted);white-space:nowrap}.slab-badge.adv{color:var(--teal);border-color:var(--teal)}.slab-badge.due{color:var(--due);border-color:var(--due)}.slab-badge.accent{color:var(--accent);border-color:var(--accent)}.dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.dot-accent{background:var(--accent)}.dot-teal{background:var(--teal)}.dot-due{background:var(--due)}.stats-row{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--line)}.stat{padding:14px 16px;border-right:1px solid var(--line);text-align:center}.stat:last-child{border-right:none}.stat-num{font-size:1.4rem;font-weight:700;line-height:1}.stat-num.c-accent{color:var(--accent)}.stat-num.c-teal{color:var(--teal)}.stat-num.c-due{color:var(--due)}.stat-label{font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}.browse-page{display:flex;flex-direction:column;min-height:calc(100vh - 49px)}.browse-toolbar{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid var(--line);background:var(--soft);align-items:center}.search-box{flex:1;min-width:160px;padding:7px 12px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-size:.85rem;font-family:inherit;outline:none}.search-box:focus{border-color:var(--accent)}.search-box::placeholder{color:var(--muted)}.sort-btn{padding:7px 12px;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-size:.8rem;font-family:inherit;font-weight:600;cursor:pointer;white-space:nowrap;transition:border-color .12s}.sort-btn:hover{border-color:var(--accent);color:var(--text)}.sort-btn.active{border-color:var(--accent);color:var(--accent);background:var(--soft)}.tabs{display:flex;gap:0;padding:0 20px;background:var(--panel);border-bottom:1px solid var(--line);overflow-x:auto;flex-shrink:0}.tab{padding:8px 14px;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--muted);border:none;border-bottom:2px solid transparent;background:transparent;white-space:nowrap;transition:color .12s;font-family:inherit}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}.layout{display:flex;flex:1;min-height:0}.list-pane{flex:1;overflow-y:auto;padding:14px 20px;border-right:1px solid var(--line);min-width:0}.vocab-page .list-pane{overflow-y:hidden;display:flex;flex-direction:column;min-height:0}.detail-pane{width:360px;flex-shrink:0;overflow:hidden;padding:16px 20px;display:flex;flex-direction:column;min-height:0}.status-filter{display:flex;gap:6px;margin-bottom:10px}.status-filter-btn{padding:3px 10px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .12s}.status-filter-btn:hover{border-color:var(--accent);color:var(--text)}.status-filter-btn.active{border-color:var(--accent);color:var(--accent);background:var(--soft)}.bulk-bar{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--soft);border:1px solid var(--line);margin-bottom:10px;flex-wrap:wrap;opacity:.4;pointer-events:none;transition:opacity .15s}.bulk-bar.has-selection{opacity:1;pointer-events:auto}.bulk-count{font-size:.8rem;color:var(--muted);font-weight:600;margin-right:4px}.bulk-label{font-size:.75rem;color:var(--muted)}.bulk-btn{padding:4px 10px;border:1px solid;font-size:.78rem;font-weight:600;font-family:inherit;cursor:pointer;transition:opacity .12s;background:var(--panel)}.bulk-btn:hover{opacity:.8}.bulk-btn.learning{border-color:var(--teal);color:var(--teal)}.bulk-btn.mastered{border-color:var(--accent);color:var(--accent)}.bulk-btn.unknown{border-color:var(--line);color:var(--muted)}.bulk-btn.active{box-shadow:0 0 0 2px var(--accent)}.bulk-deselect{margin-left:auto;padding:4px 10px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.78rem;font-family:inherit;cursor:pointer}.bulk-deselect:hover{color:var(--due);border-color:var(--due)}.stats{font-size:.78rem;color:var(--muted);margin-bottom:10px}.word-grid{display:flex;flex-direction:column;gap:3px}.word-card{padding:9px 12px;background:var(--soft);border:1px solid var(--line);display:flex;align-items:center;gap:8px;transition:border-color .1s}.word-card:hover{border-color:var(--accent)}.word-card.selected{border-color:var(--accent);background:var(--panel)}.word-card[data-status=in_progress]{border-left:3px solid var(--teal)}.word-card[data-status=mastered]{border-left:3px solid var(--accent)}.word-check-zone{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;align-self:stretch;margin:-9px 0 -9px -12px;padding:9px 4px 9px 12px;cursor:pointer}.word-checkbox{flex-shrink:0;width:13px;height:13px;cursor:pointer;accent-color:var(--accent);pointer-events:none}.word-body{flex:1;display:flex;justify-content:space-between;align-items:center;cursor:pointer;min-width:0}.word-text{font-size:.95rem;font-weight:600;color:var(--text)}.word-rank{font-size:.7rem;color:var(--muted);font-variant-numeric:tabular-nums}.word-article{font-size:.8rem;font-weight:400;margin-right:3px}.word-article.der{color:var(--teal)}.word-article.die{color:var(--due)}.word-article.das{color:var(--accent)}.word-card[data-type=noun]{border-left:3px solid var(--teal)}.word-card[data-type=verb]{border-left:3px solid var(--accent)}.word-card[data-type=adjective]{border-left:3px solid var(--adj)}.word-card[data-type=adverb],.word-card[data-type=preposition],.word-card[data-type=conjunction],.word-card[data-type=pronoun],.word-card[data-type=article],.word-card[data-type=particle],.word-card[data-type=interrogative],.word-card[data-type=numeral]{border-left:3px solid var(--muted)}.word-card[data-status=in_progress]{border-left-color:var(--teal)!important}.word-card[data-status=mastered]{border-left-color:var(--accent)!important}.pagination{display:flex;gap:6px;align-items:center;justify-content:center;margin-top:16px;padding-bottom:24px}.page-btn{padding:5px 10px;border:1px solid var(--line);background:var(--soft);color:var(--muted);font-size:.78rem;font-family:inherit;cursor:pointer;transition:border-color .12s}.page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.page-btn:disabled{opacity:.35;cursor:default}.page-btn.active{border-color:var(--accent);color:var(--accent);background:var(--panel);font-weight:700}.page-info{font-size:.78rem;color:var(--muted)}.detail-empty{color:var(--muted);font-size:.85rem;text-align:center;margin-top:60px}.detail-content{display:flex;flex-direction:column;gap:0;flex:1;min-height:0}.detail-word{font-size:1.6rem;font-weight:700;color:var(--text);margin-bottom:10px}.detail-meta{display:flex;gap:8px;align-items:center;margin-bottom:20px;flex-wrap:wrap}.report-btn{margin-left:auto;padding:2px 8px;font-size:.72rem;background:none;border:1px solid var(--line);color:var(--muted);cursor:pointer}.report-btn:hover{border-color:var(--c-accent);color:var(--c-accent)}.report-sent{margin-left:auto;font-size:.72rem;color:var(--c-teal);font-weight:600}.report-form{margin-bottom:16px}.tag{padding:3px 8px;border:1px solid var(--line);font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.neighbors-section{display:flex;flex-direction:column;gap:8px;flex:1;min-height:0;overflow:hidden}.neighbors-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.analyze-actions{display:flex;gap:6px;flex-wrap:wrap}.analyze-action-btn{padding:6px 12px;border:1px solid var(--line);background:var(--soft);color:var(--text);font-size:.78rem;font-family:inherit;cursor:pointer}.analyze-action-btn:hover{border-color:var(--accent)}.analyze-action-btn.learning{border-left:3px solid var(--teal)}.analyze-action-btn.passive{border-left:3px solid var(--accent)}.analyze-action-btn.mastered{border-left:3px solid var(--want)}.analyze-action-btn.small{padding:4px 8px;font-size:.72rem}.analyze-action-btn:disabled{opacity:.4;cursor:default}.analyze-action-btn:disabled:hover{border-color:var(--line)}.neighbor-list{display:flex;flex-direction:column;gap:2px;flex:1;overflow-y:auto;min-height:0}.neighbor-row{display:flex;align-items:center;gap:8px;padding:4px 6px;cursor:default;font-size:.82rem}.neighbor-row.checked{background:var(--soft)}.neighbor-checkbox{cursor:pointer;flex-shrink:0}.neighbor-word{cursor:pointer;color:var(--text);flex:1}.neighbor-word:hover{color:var(--accent)}.neighbor-type{font-size:.7rem;color:var(--muted)}.neighbor-status{font-size:.68rem;padding:1px 5px;border:1px solid var(--line);color:var(--muted)}.neighbor-status.mastered{color:var(--want);border-color:var(--want)}.neighbor-status.learning{color:var(--teal);border-color:var(--teal)}.neighbor-bulk-actions{display:flex;align-items:center;gap:6px;flex-wrap:wrap;padding:6px 8px;margin-bottom:4px;background:var(--soft);border:1px solid var(--line)}.neighbor-bulk-label{font-size:.76rem;color:var(--muted);font-weight:600;margin-right:2px}.empty{text-align:center;padding:32px 20px;color:var(--muted);font-size:.85rem}.loading{text-align:center;padding:40px;color:var(--muted);font-size:.85rem}.error{color:var(--due);padding:12px;font-size:.85rem;text-align:center}.spinner{width:24px;height:24px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.definition-section{margin-bottom:14px}.definition-translation{font-size:.9rem;color:var(--muted);font-style:italic}.examples-section{margin-bottom:18px;display:flex;flex-direction:column;gap:8px}.examples-heading{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.example-list{list-style:none;display:flex;flex-direction:column;gap:6px}.example-item{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;background:var(--soft);border-left:2px solid var(--line)}.example-body{flex:1;display:flex;flex-direction:column;gap:2px}.example-de{font-size:.85rem;color:var(--text)}.example-en{font-size:.75rem;color:var(--muted)}.example-delete-btn{flex-shrink:0;padding:0 4px;background:transparent;border:none;color:var(--muted);font-size:15px;line-height:1;cursor:pointer}.example-delete-btn:hover{color:var(--due)}.add-example-btn{align-self:flex-start;padding:4px 10px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.78rem;font-family:inherit;cursor:pointer}.add-example-btn:hover{border-color:var(--accent);color:var(--text)}.add-example-form{display:flex;flex-direction:column;gap:8px}.example-textarea{padding:7px 10px;border:1px solid var(--line);background:var(--soft);color:var(--text);font-size:.82rem;font-family:inherit;line-height:1.5;resize:vertical;outline:none}.example-textarea:focus{border-color:var(--accent)}.example-textarea::placeholder{color:var(--muted)}.add-example-actions{display:flex;gap:8px}.detail-actions{display:flex;gap:8px;margin-bottom:16px}.detail-actions .bulk-btn.active{box-shadow:0 0 0 2px var(--accent)}.analyze-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.analyze-input-area{padding:14px 20px;background:var(--soft);border-bottom:1px solid var(--line);display:flex;gap:10px;align-items:flex-start;flex-shrink:0}.analyze-textarea{flex:1;padding:9px 12px;border:1px solid var(--line);background:var(--panel);color:var(--text);font-size:.85rem;line-height:1.6;resize:vertical;outline:none;font-family:inherit}.analyze-textarea:focus{border-color:var(--accent)}.analyze-textarea::placeholder{color:var(--muted)}.analyze-btn{padding:9px 18px;border:none;background:var(--accent);color:#fff;font-size:.85rem;font-weight:700;font-family:inherit;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:opacity .12s}.analyze-btn:hover:not(:disabled){opacity:.85}.analyze-btn:disabled{opacity:.45;cursor:default}.analyze-stats{font-size:.75rem;color:var(--muted);margin-bottom:10px}.annotated-text{line-height:2.2;font-size:.95rem;margin-bottom:16px;padding:14px;background:var(--soft);border:1px solid var(--line)}.token{padding:1px 2px;cursor:default;transition:filter .1s}.token.token-mastered{background:rgba(31,138,112,.15);color:var(--teal)}.token.token-learning{background:rgba(143,95,43,.12);color:var(--accent)}.token.token-unknown{background:rgba(184,92,43,.1);color:var(--due)}.token.token-grey{color:var(--muted)}.token.token-not-in-vocab{color:var(--muted);text-decoration:underline dotted;cursor:pointer}.token.token-ignored{color:var(--line);cursor:default}.token.token-selected{outline:2px solid var(--accent)}.token-mastered:hover,.token-learning:hover,.token-unknown:hover,.token-not-in-vocab:hover{filter:brightness(1.3);cursor:pointer}.vocab-panel{display:flex;flex-direction:column;gap:14px}.vocab-collapsible{display:flex;justify-content:space-between;align-items:center;width:100%;background:transparent;border:none;cursor:pointer;padding:4px 0;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:700;font-family:inherit}.vocab-collapsible:hover{opacity:.75}.vocab-collapse-arrow{font-size:.7rem;color:var(--muted)}.vocab-text-toggle{color:var(--muted)}.vocab-mastered{color:var(--accent)}.vocab-in_progress{color:var(--teal)}.vocab-unknown{color:var(--due)}.vocab-not-in-vocab{color:var(--muted)}.vocab-group-words{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}.vocab-word-btn{padding:4px 10px;border:1px solid var(--line);background:var(--soft);color:var(--text);font-size:.8rem;font-family:inherit;cursor:pointer;transition:border-color .1s}.vocab-word-btn:hover{border-color:var(--accent)}.vocab-word-btn.selected{border-color:var(--accent);color:var(--accent)}.vocab-unmatched-entry{display:flex;align-items:center;gap:4px}.vocab-unmatched-token{padding:4px 10px;border:1px solid var(--line);background:var(--soft);color:var(--muted);font-size:.8rem;font-family:inherit;cursor:pointer;transition:border-color .1s}.vocab-unmatched-token:hover{border-color:var(--accent);color:var(--text)}.vocab-unmatched-token.selected{border-color:var(--accent);color:var(--accent)}.vocab-icon-btn{padding:3px 7px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.8rem;font-family:inherit;line-height:1;cursor:pointer}.vocab-icon-btn:hover{border-color:var(--accent);color:var(--text)}.add-word-form{display:flex;flex-direction:column;gap:14px}.add-word-form h3{font-size:.95rem;font-weight:700;color:var(--text)}.add-word-form label{display:flex;flex-direction:column;gap:4px;font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}.add-word-form select{padding:6px 10px;border:1px solid var(--line);background:var(--soft);color:var(--text);font-size:.85rem;font-family:inherit;outline:none}.add-word-form select:focus{border-color:var(--accent)}.add-word-form-actions{display:flex;gap:8px}.add-word-btn-save{padding:6px 14px;border:none;background:var(--accent);color:#fff;font-size:.82rem;font-weight:700;font-family:inherit;cursor:pointer}.add-word-btn-save:hover{opacity:.85}.add-word-btn-ignore,.add-word-btn-cancel{padding:6px 14px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.82rem;font-family:inherit;cursor:pointer}.add-word-btn-ignore:hover{border-color:var(--due);color:var(--due)}.add-word-btn-cancel:hover{border-color:var(--accent);color:var(--text)}.trainer-page{display:flex;flex-direction:column;align-items:center;padding:36px 20px;overflow-y:auto;min-height:0;flex:1}.trainer-setup{width:100%;max-width:480px;display:flex;flex-direction:column;gap:24px}.trainer-setup-title{font-size:1.3rem;font-weight:700;color:var(--text);margin:0}.trainer-setup-sub{font-size:.85rem;color:var(--muted);margin:-16px 0 0}.trainer-section{display:flex;flex-direction:column;gap:8px}.trainer-section-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.trainer-deck-btns,.trainer-limit-btns{display:flex;flex-wrap:wrap;gap:6px}.trainer-deck-btn,.trainer-limit-btn{padding:7px 14px;border:1px solid var(--line);background:transparent;color:var(--text);font-size:.82rem;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .1s,color .1s,background .1s}.trainer-deck-btn:hover,.trainer-limit-btn:hover{border-color:var(--accent);color:var(--text)}.trainer-deck-btn.active,.trainer-limit-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}.trainer-start-btn{padding:14px;border:none;background:var(--teal);color:#fff;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .12s}.trainer-start-btn:hover:not(:disabled){opacity:.88}.trainer-start-btn:disabled{opacity:.4;cursor:default}.trainer-empty-hint{font-size:.82rem;color:var(--muted);margin:-14px 0 0}.flashcard-wrap{width:100%;max-width:480px;display:flex;flex-direction:column;gap:16px}.flashcard-progress-row{display:flex;align-items:center;gap:10px}.flashcard-counter{font-size:.72rem;font-weight:700;color:var(--muted);white-space:nowrap;font-variant-numeric:tabular-nums}.flashcard-prog-bar{flex:1;height:4px;background:var(--line);overflow:hidden}.flashcard-prog-fill{height:100%;background:var(--accent);transition:width .3s ease}.flashcard{background:var(--soft);border:1px solid var(--line);min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 24px;cursor:pointer;position:relative;-webkit-user-select:none;user-select:none;transition:border-color .15s}.flashcard:hover{border-color:var(--accent)}.flashcard.flipped{cursor:default}.flashcard.flipped:hover{border-color:var(--line)}.flashcard-front,.flashcard-back{display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;width:100%}.flashcard-back,.flashcard.flipped .flashcard-front{display:none}.flashcard.flipped .flashcard-back{display:flex}.flashcard-hint{font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.flashcard-word{font-size:2rem;font-weight:700;color:var(--text);line-height:1.1}.flashcard-rank{font-size:.72rem;color:var(--muted);font-variant-numeric:tabular-nums}.flashcard-type-tag{font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border:1px solid var(--line);padding:2px 7px}.flashcard-translation{font-size:1.25rem;font-weight:600;color:var(--text);line-height:1.4}.flashcard-word-small{font-size:.85rem;color:var(--muted);margin-top:4px}.flashcard-no-translation{font-size:.85rem;color:var(--muted);font-style:italic}.flashcard-actions{display:flex;gap:10px;opacity:0;pointer-events:none;transition:opacity .15s}.flashcard-actions.visible{opacity:1;pointer-events:auto}.flashcard-btn{flex:1;padding:14px;border:none;font-size:.9rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px;transition:opacity .12s}.flashcard-btn:active{opacity:.8}.flashcard-btn-yes{background:var(--teal);color:#fff}.flashcard-btn-yes:hover{opacity:.88}.flashcard-btn-no{background:var(--soft);color:var(--text);border:1px solid var(--line)}.flashcard-btn-no:hover{border-color:var(--due);color:var(--due)}.flashcard-btn-icon{font-size:1rem;font-weight:900}.flashcard-tap-hint{text-align:center;font-size:.7rem;color:var(--muted);opacity:.6}.trainer-done{width:100%;max-width:560px;display:flex;flex-direction:column;gap:20px;align-items:center}.trainer-done-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:4px}.trainer-done-score{display:flex;align-items:baseline;gap:4px;font-size:3rem;font-weight:800;line-height:1}.trainer-done-slash{color:var(--muted);font-size:2rem}.trainer-done-total{color:var(--muted)}.trainer-done-label{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}.trainer-promote-btn{padding:12px 24px;border:none;background:var(--teal);color:#fff;font-size:.9rem;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .12s}.trainer-promote-btn:hover{opacity:.88}.trainer-promoted-msg{padding:10px 20px;background:var(--soft);border:1px solid var(--teal);color:var(--teal);font-size:.85rem;font-weight:600}.trainer-restart-btn{padding:8px 20px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.82rem;font-family:inherit;cursor:pointer;transition:border-color .1s,color .1s}.trainer-restart-btn:hover{border-color:var(--accent);color:var(--text)}.trainer-done-lists{width:100%;display:flex;flex-direction:column;gap:16px}.trainer-done-group{display:flex;flex-direction:column;gap:8px}.trainer-done-group-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}.trainer-chips{display:flex;flex-wrap:wrap;gap:5px}.trainer-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;background:var(--soft);border:1px solid var(--line);font-size:.8rem;color:var(--text)}.trainer-chip-yes{border-left:3px solid var(--teal)}.trainer-chip-no{border-left:3px solid var(--due)}.trainer-chip-hard{border-left:3px solid var(--accent)}.trainer-stats-row{display:flex;gap:24px}.trainer-stat{display:flex;flex-direction:column;align-items:center;gap:2px}.trainer-stat-num{font-size:1.8rem;font-weight:800;color:var(--text);line-height:1}.trainer-stat-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted)}.flashcard-dir-badge{position:absolute;top:8px;left:10px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:var(--panel);padding:2px 6px;border:1px solid var(--line)}.flashcard-level-badge{position:absolute;top:8px;right:10px;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);background:var(--panel);padding:2px 6px;border:1px solid var(--line)}.srs-actions{display:flex;gap:8px}.srs-actions .flashcard-btn{flex:1;font-weight:700;font-size:.85rem}.srs-btn-again{background:var(--due);color:#fff}.srs-btn-again:hover{opacity:.85}.srs-btn-hard{background:var(--accent);color:#fff}.srs-btn-hard:hover{opacity:.85}.srs-btn-good{background:var(--teal);color:#fff}.srs-btn-good:hover{opacity:.85}.srs-btn-very-good{background:#2e7d32;color:#fff}.srs-btn-very-good:hover{opacity:.85}.preview-word-list{display:flex;flex-direction:column;gap:8px}.preview-word-row{display:flex;align-items:baseline;gap:8px;padding:8px 12px;background:var(--soft);border:1px solid var(--line);font-size:.88rem}.preview-word-de{font-weight:700;color:var(--text)}.preview-word-sep,.preview-word-en{color:var(--muted)}.trainer-done-summary{display:flex;gap:8px;flex-wrap:wrap}.done-tag{padding:4px 10px;font-size:.75rem;font-weight:700;border-radius:2px}.done-tag-good{background:var(--teal);color:#fff}.done-tag-hard{background:var(--accent);color:#fff}.done-tag-again{background:var(--due);color:#fff}.trainer-saving{font-size:.8rem;color:var(--muted);font-style:italic}@media (max-width: 640px){.app{margin:0}.stats-row{grid-template-columns:1fr 1fr}.stat{border-bottom:1px solid var(--line)}.slab{flex-direction:column;align-items:flex-start}.slab-right{align-self:flex-end}.layout{flex-direction:column}.list-pane{border-right:none;border-bottom:1px solid var(--line)}.detail-pane{width:100%;display:none}.detail-pane.has-selection{display:block}.head-nav{display:none}}.c-want{color:var(--want)}.vstats{display:grid;grid-template-columns:repeat(3,auto) 1fr;border-bottom:1px solid var(--line);background:var(--soft)}.vstat{padding:12px 16px;border-right:1px solid var(--line);text-align:center}.vstat-num{font-size:1.35rem;font-weight:700;line-height:1}.vstat-label{font-size:.68rem;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-top:3px}.vstat-progress-cell{padding:12px 16px;display:flex;flex-direction:column;justify-content:center;gap:5px;border-right:none}.vstat-level-row{display:flex;align-items:center;gap:8px}.vstat-level-badge{font-size:.8rem;font-weight:800;color:var(--accent);letter-spacing:.04em}.vstat-level-info{font-size:.72rem;color:var(--muted)}.vstat-bar{height:6px;background:var(--line);display:flex;overflow:hidden}.vstat-fill{height:100%;transition:width .4s ease}.vstat-fill.level{background:var(--accent)}.vstat-level-ticks{display:flex;gap:10px}.vstat-tick{font-size:.65rem;font-weight:700;color:var(--line);text-transform:uppercase;letter-spacing:.05em}.vstat-tick.done{color:var(--accent)}.vocab-page{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.vocab-filter-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;border-bottom:1px solid var(--line);background:var(--panel)}.vocab-filter-search{flex:0 0 240px;padding:6px 10px;border:1px solid var(--line);background:var(--bg);color:var(--text);font-size:.82rem;font-family:inherit;outline:none}.vocab-filter-search:focus{border-color:var(--accent)}.export-csv-btn{margin-left:auto;padding:5px 12px;font-size:.78rem;background:none;border:1px solid var(--line);color:var(--muted);cursor:pointer;font-family:inherit;white-space:nowrap}.export-csv-btn:hover{border-color:var(--accent);color:var(--accent)}.vocab-filter-types{display:flex;gap:4px}.vtab-bar{display:flex;gap:0;border:1px solid var(--line);border-radius:4px 4px 0 0;overflow:hidden}.vtab-btn{flex:1;padding:10px 12px;border:none;border-right:1px solid var(--line);background:var(--soft);color:var(--muted);font-family:inherit;font-size:.82rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:background .15s,color .15s}.vtab-btn:last-child{border-right:none}.vtab-btn:hover{color:var(--text)}.vtab-btn.active{background:var(--bg);color:var(--text)}.vtab-btn.active.vtab-all{border-bottom:3px solid var(--fg)}.vtab-btn.active.vtab-pool{border-bottom:3px solid var(--muted)}.vtab-btn.active.vtab-want_to_learn{border-bottom:3px solid var(--want)}.vtab-btn.active.vtab-learning{border-bottom:3px solid var(--teal)}.vtab-btn.active.vtab-mastered{border-bottom:3px solid var(--accent)}.vtab-count{font-size:.68rem;color:var(--muted);font-weight:400}.vtab-content{border:1px solid var(--line);border-top:none;border-radius:0 0 4px 4px;flex:1;min-height:0;display:flex;flex-direction:column}.vtab-info{padding:4px 12px;font-size:.72rem;color:var(--muted);border-bottom:1px solid var(--line)}.vcol-type-btn{padding:2px 7px;border:1px solid var(--line);background:transparent;color:var(--muted);font-size:.7rem;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color .1s,color .1s}.vcol-type-btn:hover{border-color:var(--accent);color:var(--text)}.vcol-type-btn.active{border-color:var(--accent);color:var(--accent);background:var(--soft)}.vcol-actions{padding:8px 12px;background:var(--soft);border-bottom:1px solid var(--line);flex-shrink:0;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.vcol-actions:not(.visible) .vcol-mv-btn,.vcol-actions:not(.visible) .vcol-mv-btns{opacity:.3;pointer-events:none}.vcol-actions:not(.visible) .vcol-sel-count{color:var(--muted);opacity:.5}.vcol-sel-count{font-size:.72rem;font-weight:700;color:var(--muted);white-space:nowrap;flex-shrink:0}.vcol-mv-btns{display:flex;gap:5px;flex-wrap:wrap}.vcol-mv-btn{padding:5px 10px;border:none;font-size:.75rem;font-weight:700;font-family:inherit;cursor:pointer;letter-spacing:.02em;transition:opacity .12s;white-space:nowrap}.vcol-mv-btn:hover{opacity:.82}.mv-want{background:var(--want);color:#fff}.mv-learning{background:var(--teal);color:#fff}.mv-mastered{background:var(--accent);color:#fff}.mv-remove{background:transparent;color:var(--muted);border:1px solid var(--line)}.mv-remove:hover{border-color:var(--due);color:var(--due)}.vcol-list{flex:1;overflow-y:auto;padding:4px 0}.vcol-empty{text-align:center;padding:24px 12px;color:var(--muted);font-size:.8rem}.vrow{display:flex;align-items:center;padding:5px 12px 5px 0;border-left:3px solid transparent;transition:background .08s;cursor:default}.vrow:hover{background:var(--soft)}.vrow.vrow-selected{background:var(--soft);border-left-color:var(--accent)}.vrow.vrow-checked{background:var(--soft)}.vrow[data-type=noun]{border-left-color:var(--teal)}.vrow[data-type=verb]{border-left-color:var(--accent)}.vrow[data-type=adjective]{border-left-color:var(--adj)}.vrow.vrow-selected{border-left-color:var(--text)!important}.vrow-check{flex-shrink:0;width:32px;display:flex;align-items:center;justify-content:center;align-self:stretch;cursor:pointer}.vrow-checkbox{width:12px;height:12px;accent-color:var(--accent);pointer-events:none}.vrow-body{flex:1;display:flex;justify-content:space-between;align-items:center;cursor:pointer;min-width:0;padding-right:4px}.vrow-word{font-size:.85rem;font-weight:600;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.vrow-article{font-size:.72rem;font-weight:400;margin-right:3px}.vrow-article.der{color:var(--teal)}.vrow-article.die{color:var(--due)}.vrow-article.das{color:var(--accent)}.vrow-rank{font-size:.68rem;color:var(--muted);font-variant-numeric:tabular-nums;flex-shrink:0;margin-left:4px}.vrow-translation{font-size:.75rem;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:1;min-width:0;margin-left:8px}.vrow-status{font-size:.65rem;padding:1px 6px;border-radius:3px;flex-shrink:0;margin-left:4px}.vrow-status.learning{background:var(--teal);color:#fff}.vrow-status.mastered{background:var(--accent);color:#fff}.vcol-pagination{display:flex;align-items:center;justify-content:center;gap:8px;padding:8px;border-top:1px solid var(--line);flex-shrink:0;background:var(--soft)}.vcol-page-btn{padding:3px 9px;border:1px solid var(--line);background:var(--panel);color:var(--muted);font-family:inherit;font-size:.78rem;cursor:pointer}.vcol-page-btn:hover:not(:disabled){border-color:var(--accent);color:var(--text)}.vcol-page-btn:disabled{opacity:.35;cursor:default}.vcol-page-info{font-size:.72rem;color:var(--muted)}a.slab{text-decoration:none;color:inherit;display:flex}@media (max-width: 900px){.vstats{grid-template-columns:1fr 1fr 1fr}.vstat-progress-cell{grid-column:span 3;border-top:1px solid var(--line)}}@media (max-width: 560px){.vstats{grid-template-columns:1fr 1fr}.vstat-progress-cell{display:none}}.auth-info{display:flex;align-items:center;gap:8px}.auth-greeting{font-size:.78rem;color:var(--muted);white-space:nowrap}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:rgba(0,0,0,.45);display:flex;align-items:center;justify-content:center}.login-modal{background:var(--panel);border:1px solid var(--line);padding:32px;width:340px;max-width:92vw;position:relative}.login-modal h2{font-size:1.2rem;margin-bottom:20px;color:var(--text)}.login-close{position:absolute;top:12px;right:14px;background:none;border:none;font-size:1.4rem;color:var(--muted);cursor:pointer}.login-input{display:block;width:100%;padding:10px 12px;margin-bottom:12px;background:var(--soft);border:1px solid var(--line);color:var(--text);font-size:.9rem;font-family:inherit}.login-input:focus{outline:none;border-color:var(--accent)}.login-submit{display:block;width:100%;padding:10px;margin-top:4px;background:var(--accent);color:#fff;border:none;font-size:.9rem;font-weight:600;cursor:pointer}.login-submit:disabled{opacity:.6;cursor:not-allowed}.login-error{color:var(--due);font-size:.82rem;margin-bottom:10px}.login-switch{margin-top:16px;font-size:.82rem;color:var(--muted);text-align:center}.login-link{background:none;border:none;color:var(--accent);cursor:pointer;font-size:inherit;text-decoration:underline}.account-modal{width:380px}.account-email{font-size:.82rem;color:var(--muted);margin-bottom:20px}.account-section{margin-bottom:20px}.account-label{display:block;font-size:.78rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.account-row{display:flex;gap:8px}.account-row .login-input{flex:1;margin-bottom:0}.account-save{flex:0 0 auto;width:auto;padding:8px 16px}.account-msg{color:var(--teal);font-size:.82rem;margin-bottom:10px}.account-logout{border-top:1px solid var(--line);padding-top:16px}.account-logout-btn{background:var(--muted)}
