:root{color:#1a1a1a;background:#f5f5f5;font-family:system-ui,sans-serif}body{margin:0}.layout{min-height:100vh;display:flex}.sidenav{color:#cdd6f4;background:#1e1e2e;flex-direction:column;gap:.25rem;width:180px;min-width:180px;padding:1.5rem 0;display:flex}.sidenav-user{margin-top:auto;padding:1rem 1.25rem}.sign-in-screen{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:100vh;display:flex}.sidenav-title{color:#fff;letter-spacing:.05em;padding:0 1.25rem 1rem;font-size:1.1rem;font-weight:700}.nav-link{color:#a6adc8;border-radius:0;padding:.55rem 1.25rem;font-size:.95rem;text-decoration:none;transition:background .1s,color .1s;display:block}.nav-link:hover{color:#cdd6f4;background:#313244}.nav-link.active{color:#fff;background:#45475a}.main-content{flex:1;padding:2rem;overflow-y:auto}.center{text-align:center;flex-direction:column;align-items:center;gap:1rem;margin-top:4rem;display:flex}.muted{color:#888}.error{color:#dc2626}button{cursor:pointer;border:none;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:600;transition:opacity .15s}button:hover{opacity:.85}.btn-primary{color:#fff;background:#6366f1;align-self:flex-start}.btn-again{color:#991b1b;background:#fee2e2}.btn-hard{color:#92400e;background:#fef3c7}.btn-good{color:#065f46;background:#d1fae5}.btn-easy{color:#1e40af;background:#dbeafe}.btn-delete{color:#ccc;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.2rem .4rem;font-size:.8rem}.btn-delete:hover{color:#dc2626;opacity:1;background:#fee2e2}.word-table{border-collapse:collapse;background:#fff;border-radius:10px;width:100%;overflow:hidden;box-shadow:0 2px 12px #00000014}.word-table th,.word-table td{text-align:left;border-bottom:1px solid #f0f0f0;padding:.75rem 1rem}.word-table th{text-transform:uppercase;letter-spacing:.05em;color:#555;background:#f5f5f5;font-size:.85rem;font-weight:600}.word-table tr:last-child td{border-bottom:none}.word-table tbody tr:hover{background:#fafafa}.use-case-table{border-collapse:collapse;width:100%}.use-case-table th,.use-case-table td{text-align:left;border-bottom:1px solid #efefef;padding:.5rem 1rem;font-size:.9rem}.use-case-table th{text-transform:uppercase;letter-spacing:.04em;color:#888;background:#f0f0f0;font-size:.8rem;font-weight:600}.new-word-input{border:1px solid #d1d5db;border-radius:6px;outline:none;width:100%;padding:.35rem .6rem;font-family:inherit;font-size:.95rem}.new-word-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #e0e7ff}.uc-input{background:0 0;border:none;outline:none;width:100%;padding:0;font-family:inherit;font-size:.9rem}.uc-input:focus{background:#fffbea;border-radius:3px;padding:0 4px;box-shadow:inset 0 0 0 2px #f59e0b}.uc-row-new{background:#f0f7ff}.btn-add-uc{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;margin:.5rem 0 .5rem 1rem;padding:.35rem .9rem;font-size:.85rem;font-weight:600}.btn-add-uc:hover{opacity:.85}.btn-generate-uc{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;padding:.35rem .9rem;font-size:.85rem;font-weight:600}.btn-generate-uc:hover{opacity:.85}.btn-generate-uc:disabled{opacity:.5;cursor:not-allowed}.sentence-tokens{flex-wrap:wrap;gap:.35rem;margin:0 0 1rem;display:flex}.sentence-word{color:#111;cursor:pointer;-webkit-user-select:none;user-select:none;background:#ede9fe;border-radius:4px;padding:.2rem .45rem;font-size:1rem;transition:background .1s,color .1s}.sentence-word:hover{background:#ddd6fe}.sentence-word.selected{color:#fff;background:#7c3aed}.word-info{flex-direction:column;gap:.25rem;display:flex}.canonical-result{color:#555;margin:0;font-size:.95rem}.word-info-notes{color:#666;margin:0;font-size:.9rem;font-style:italic}.review-container{flex-direction:column;gap:1.25rem;display:flex}.review-layout{align-items:flex-start;gap:1.5rem;display:flex}.review-panel{background:#fff;border-radius:12px;flex:1;min-height:180px;padding:1.5rem 2rem;box-shadow:0 2px 12px #00000014}.review-word{margin:0 0 1.25rem;font-size:2rem;font-weight:700}.review-notes{color:#333;white-space:pre-wrap;margin:0;font-size:.95rem;line-height:1.6}.review-notes-placeholder{margin:0;font-style:italic}.review-actions{display:flex}.card{background:#fff;border-radius:12px;flex-direction:column;gap:1.25rem;max-width:560px;padding:2rem;display:flex;box-shadow:0 2px 12px #00000014}.progress{margin:0;font-size:.85rem}.prompt{margin:0;font-size:1.35rem;line-height:1.6}.answer-block{background:#f9f9f9;border-left:3px solid #6366f1;border-radius:4px;flex-direction:column;gap:.4rem;padding:.75rem 1rem;display:flex}.answer-block p{margin:0;font-size:.95rem}.label{color:#555;font-weight:600}.rate-label{margin:0;font-size:.85rem}.rating-buttons{grid-template-columns:repeat(4,1fr);gap:.5rem;display:grid}.word-row{cursor:pointer;-webkit-user-select:none;user-select:none}.word-row:hover{background:#f5f5f5}.expand-icon{color:#aaa;width:1.2rem;font-size:.75rem;display:inline-block}.detail-row td{background:#fafafa}.see-words-toolbar{gap:.5rem;margin-bottom:1rem;display:flex}.btn-add-word{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:600}.btn-add-word:hover{opacity:.85}.word-row-pending td{background:#f0f7ff}.btn-save-word{color:#fff;cursor:pointer;white-space:nowrap;background:#16a34a;border:none;border-radius:6px;padding:.3rem .7rem;font-size:.85rem;font-weight:600}.btn-save-word:hover{opacity:.85}.btn-save-word:disabled{opacity:.45;cursor:not-allowed}.notes-section{flex-direction:column;gap:.25rem;padding:.75rem 1rem .5rem;display:flex}.notes-label{text-transform:uppercase;letter-spacing:.04em;color:#888;font-size:.8rem;font-weight:600}.notes-textarea{resize:vertical;box-sizing:border-box;border:1px solid #e5e7eb;border-radius:6px;outline:none;width:100%;padding:.5rem;font-family:inherit;font-size:.9rem}.notes-textarea:focus{border-color:#6366f1;box-shadow:0 0 0 2px #e0e7ff}.uc-actions{gap:.5rem;margin:.5rem 0 .5rem 1rem;display:flex}.settings-page{flex-direction:column;gap:2rem;max-width:700px;display:flex}.settings-section{flex-direction:column;gap:1rem;display:flex}.settings-section-header{justify-content:space-between;align-items:center;display:flex}.settings-section-title{margin:0;font-size:1.1rem;font-weight:700}.sub-badge{border-radius:4px;padding:.2rem .6rem;font-size:.75rem;font-weight:600}.sub-badge-active{color:#065f46;background:#d1fae5}.sub-badge-free{color:#6b7280;background:#f3f4f6}.sub-badge-due{color:#92400e;background:#fef3c7}.sub-notice{border-radius:4px;margin:0;padding:.5rem .75rem;font-size:.875rem}.sub-notice-success{color:#065f46;background:#d1fae5}.sub-notice-cancelled{color:#92400e;background:#fef3c7}.deck-active-badge{color:#065f46;background:#d1fae5;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.texts-layout{align-items:flex-start;gap:1.5rem;height:calc(100vh - 4rem);display:flex}.texts-left{flex-direction:column;width:660px;min-width:660px;height:100%;display:flex;overflow-y:auto}.texts-grid{flex-wrap:wrap;gap:1.25rem;padding:4px;display:flex}.text-card{cursor:pointer;background:#fff;border-radius:12px;flex-direction:column;width:300px;height:300px;transition:box-shadow .15s;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 12px #00000014}.text-card:hover{box-shadow:0 2px 12px #00000026}.text-card-selected{box-shadow:0 0 0 3px #93c5fd,0 2px 12px #00000014}.text-card-actions{z-index:1;gap:.25rem;display:flex;position:absolute;top:.5rem;right:.5rem}.text-card:hover .text-card-actions{display:flex}.text-card-action-btn{cursor:pointer;color:#111;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:.9rem;display:flex}.text-card-action-btn:hover{background:#e5e7eb}.text-card-title{white-space:nowrap;text-overflow:ellipsis;border-bottom:1px solid #f0f0f0;flex-shrink:0;padding:.75rem 1rem;font-size:.95rem;font-weight:700;overflow:hidden}.text-card-body{color:#444;flex:1;padding:.75rem 1rem 0;font-size:.85rem;line-height:1.6;position:relative;overflow:hidden}.text-card-body p{white-space:pre-wrap;margin:0}.text-card-fade{background:linear-gradient(#0000,#fff);height:80px;position:absolute;bottom:0;left:0;right:0}.texts-right{background:#fff;border-radius:12px;flex:1;height:88vh;padding:1.5rem 2rem;overflow-y:auto;box-shadow:0 2px 12px #00000014}.texts-preview-title{margin:0 0 1rem;font-size:1.25rem}.texts-preview-content{color:#333;white-space:pre-wrap;-webkit-user-select:text;user-select:text;margin:0;font-size:.95rem;line-height:1.8}.selection-anchor{anchor-name:--selection;width:0;height:0;position:fixed}.selection-popover{position-anchor:--selection;top:calc(anchor(bottom) + 8px);left:anchor(center);color:#cdd6f4;z-index:100;background:#1e1e2e;border-radius:10px;flex-direction:column;gap:.5rem;min-width:160px;max-width:320px;padding:.6rem .9rem;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 20px #00000040}.selection-popover-text{color:#a6e3a1;word-break:break-word;margin:0;font-size:.9rem}.selection-popover-btn{align-self:stretch;padding:.35rem .7rem;font-size:.85rem}.selection-popover-exists{color:#a6adc8;margin:0;font-size:.8rem}.word-popover-anchor{anchor-name:--word-highlight;width:0;height:0;position:fixed}.word-popover{position-anchor:--word-highlight;top:calc(anchor(bottom) + 8px);left:anchor(center);color:#cdd6f4;z-index:100;background:#1e1e2e;border-radius:10px;flex-direction:column;gap:.4rem;min-width:200px;max-width:360px;padding:.75rem 1rem;display:flex;position:fixed;transform:translate(-50%);box-shadow:0 4px 20px #00000040}.word-popover-title{color:#cba6f7;margin:0;font-size:.95rem;font-weight:700}.word-popover-notes{color:#a6adc8;margin:0;font-size:.8rem;font-style:italic}.word-popover-use-cases{flex-direction:column;gap:.3rem;margin:0;padding:0;list-style:none;display:flex}.word-popover-use-cases li{font-size:.82rem;line-height:1.4}.word-popover-fr{color:#a6e3a1}.word-popover-en{color:#a6adc8}.word-highlight{cursor:pointer;background:#fef9c3;border-radius:2px}.word-highlight:hover{background:#fef08a}.modal-backdrop{z-index:200;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:14px;flex-direction:column;gap:1.25rem;width:720px;max-width:90vw;max-height:80vh;padding:1.5rem 2rem;display:flex;overflow-y:auto;box-shadow:0 8px 40px #0003}.modal-header{justify-content:space-between;align-items:center;display:flex}.modal-title{margin:0;font-size:1.1rem;font-weight:700}.modal-field{flex-direction:column;gap:.5rem;display:flex}.modal-label{text-transform:uppercase;letter-spacing:.04em;color:#888;font-size:.8rem;font-weight:600}.modal-input{border:1px solid #d1d5db;border-radius:6px;outline:none;padding:.5rem .75rem;font-family:inherit;font-size:.95rem}.modal-input:focus{border-color:#6366f1;box-shadow:0 0 0 2px #e0e7ff}.modal-input:disabled{color:#555;background:#f5f5f5}.modal-footer{justify-content:flex-end;gap:.5rem;display:flex}.btn-cancel{color:#374151;cursor:pointer;background:#e5e7eb;border:none;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:600}.btn-cancel:hover{opacity:.85}.btn-danger{color:#fff;cursor:pointer;background:#ef4444;border:none;border-radius:8px;padding:.6rem 1rem;font-size:.9rem;font-weight:600}.btn-danger:hover{opacity:.85}.word-badge{white-space:nowrap;border-radius:4px;padding:.2rem .5rem;font-size:.75rem;font-weight:600}.word-badge-exists{color:#92400e;background:#fef3c7}.word-badge-new{color:#065f46;background:#d1fae5}
