:root{--primary: #4f46e5;--primary-hover: #4338ca;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--text-main: #1e293b;--text-sub: #64748b;--border-color: #e2e8f0;--card-bg: #ffffff;--card-shadow: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color-scheme:light}[data-theme=dark]{--primary: #818cf8;--primary-hover: #6366f1;--success: #34d399;--danger: #f87171;--warning: #fbbf24;--bg: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--text-main: #f1f5f9;--text-sub: #94a3b8;--border-color: #334155;--card-bg: #1e293b;--card-shadow: 0 20px 25px -5px rgba(0, 0, 0, .3), 0 10px 10px -5px rgba(0, 0, 0, .2);color-scheme:dark}*{box-sizing:border-box;outline:none;-webkit-tap-highlight-color:transparent}body{background-color:var(--bg);color:var(--text-main);min-height:100vh;margin:0;padding:0;overflow-x:hidden}a{font-weight:500;color:var(--primary);text-decoration:inherit}a:hover{color:var(--primary);opacity:.8}h1{font-size:2em;line-height:1.1;margin:0}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:600;font-family:inherit;background-color:var(--primary);color:#fff;cursor:pointer;transition:all .2s}button:hover{opacity:.9;transform:translateY(-1px)}button:active{transform:scale(.98)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}button:focus,button:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.save-slot-manager{max-width:1200px;margin:0 auto;padding:2rem}.header{text-align:center;margin-bottom:3rem}.header h1{font-size:2.5rem;margin-bottom:.5rem;color:var(--text-main)}.subtitle{color:var(--text-sub);font-size:1.1rem}.guide-hint-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:linear-gradient(135deg,#fffbeb,#fef3c7);border:2px solid #fbbf24;border-radius:12px;padding:1rem 1.5rem;margin-bottom:2rem;box-shadow:0 2px 8px #fbbf2426}.hint-content{display:flex;align-items:center;gap:.75rem;flex:1}.hint-icon{font-size:1.5rem;flex-shrink:0}.hint-text{color:#92400e;font-size:.95rem;line-height:1.5}.hint-text strong{color:#78350f;font-weight:700}.hint-actions{display:flex;gap:.75rem;flex-shrink:0}.hint-btn{padding:.5rem 1rem;border:none;border-radius:8px;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.hint-btn-primary{background:#f59e0b;color:#fff}.hint-btn-primary:hover{background:#d97706;transform:translateY(-1px);box-shadow:0 2px 8px #f59e0b4d}.hint-btn-secondary{background:transparent;color:#92400e;border:1px solid #d97706}.hint-btn-secondary:hover{background:#d977061a}@media(max-width:640px){.guide-hint-banner{flex-direction:column;align-items:stretch;padding:1rem}.hint-content{justify-content:center;text-align:center}.hint-actions{justify-content:center}.hint-btn{flex:1}}.slot-hero{position:relative;width:100%;height:240px;border-radius:16px;overflow:hidden;margin-bottom:2.5rem;box-shadow:0 4px 12px #0000001a}.hero-banner-image{position:absolute;inset:0;background-size:cover;background-position:center;background-repeat:no-repeat;z-index:0}.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,#4f46e5d9,#6366f1bf);display:flex;align-items:center;justify-content:center;z-index:1}.hero-content{text-align:center;color:#fff;padding:2rem}.hero-content h2{font-size:2rem;font-weight:800;margin:0 0 .75rem;text-shadow:0 2px 8px rgba(0,0,0,.3);letter-spacing:-.01em}.hero-content p{font-size:1.1rem;margin:0;opacity:.95;font-weight:500;text-shadow:0 1px 4px rgba(0,0,0,.2)}.save-slots-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.save-slot{background:var(--card-bg);border:2px solid var(--border-color);border-radius:12px;padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative;min-height:220px;display:flex;flex-direction:column}.save-slot:hover{border-color:var(--primary);box-shadow:0 4px 12px #4f46e526;transform:translateY(-2px)}.save-slot.new-slot{border-style:dashed;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-tertiary)}.save-slot.new-slot:hover{background:var(--bg-secondary)}.mascot-decoration{position:absolute;top:-20px;right:-10px;width:80px;height:80px;opacity:.3;pointer-events:none;z-index:0;transition:all .3s ease}.mascot-decoration img{width:100%;height:100%;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.save-slot.new-slot:hover .mascot-decoration{opacity:.6;transform:scale(1.1) rotate(5deg)}.slot-icon{font-size:3rem;color:var(--primary);margin-bottom:.5rem;position:relative;z-index:1}.delete-btn{position:absolute;top:.5rem;right:.5rem;background:#f44;color:#fff;border:none;border-radius:50%;width:28px;height:28px;font-size:1.5rem;line-height:1;cursor:pointer;opacity:0;transition:opacity .2s;padding:0;display:flex;align-items:center;justify-content:center}.save-slot:hover .delete-btn{opacity:1}.delete-btn:hover{background:#c00}.slot-header{margin-bottom:1rem}.slot-name{font-size:1.3rem;margin:0 0 .25rem;color:var(--text-main)}.slot-date{font-size:.85rem;color:var(--text-sub);margin:0}.slot-description{font-size:.9rem;color:var(--text-sub);margin:0 0 1rem;line-height:1.4}.slot-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;margin-bottom:1rem}.stat{display:flex;flex-direction:column;align-items:center;padding:.5rem;background:var(--bg-tertiary);border-radius:6px}.stat-label{font-size:.75rem;color:var(--text-sub);margin-bottom:.25rem}.stat-value{font-size:1.25rem;font-weight:700;color:var(--primary)}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-top:auto}.progress-fill{height:100%;background:linear-gradient(90deg,#646cff,#4c54cc);transition:width .3s ease}.dialog-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.dialog{background:var(--card-bg);border-radius:12px;padding:2rem;max-width:500px;width:90%;box-shadow:0 10px 40px #0003}.dialog h2{margin:0 0 1.5rem;color:var(--text-main)}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-main)}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid var(--border-color);border-radius:6px;font-size:1rem;font-family:inherit;transition:border-color .2s;background:var(--bg-secondary);color:var(--text-main)}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary)}.dialog-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-hover)}.btn-primary:disabled{background:var(--text-sub);cursor:not-allowed}.btn-secondary{background:var(--bg-tertiary);color:var(--text-main)}.btn-secondary:hover{background:var(--bg-secondary)}@media(max-width:1024px){.slot-hero{height:200px}.hero-content h2{font-size:1.75rem}.hero-content p{font-size:1rem}}@media(max-width:767px){.slot-hero{height:180px;margin-bottom:1.5rem;border-radius:12px}.hero-content{padding:1.5rem}.hero-content h2{font-size:1.6rem}.hero-content p{font-size:.95rem}.header{margin-bottom:2rem}.save-slots-grid{grid-template-columns:1fr}.mascot-decoration{width:60px;height:60px;top:-15px;right:-5px}}@media(max-width:480px){.save-slot-manager{padding:1.5rem 1rem}.slot-hero{height:150px;border-radius:10px}.hero-content h2{font-size:1.4rem}.hero-content p{font-size:.85rem}.header h1{font-size:2rem}.subtitle{font-size:1rem}}.preview-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);z-index:1000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-out}.preview-modal{background:var(--card-bg);width:95%;max-width:700px;max-height:85vh;border-radius:24px;padding:25px;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040;animation:slideUp .3s ease-out}.preview-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:1px solid var(--border-color)}.preview-modal-title{margin:0;font-size:1.3rem;font-weight:700;color:var(--text-main)}.preview-modal-close{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-tertiary);color:var(--text-sub);font-size:1.2rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.preview-modal-close:hover{background:var(--bg-secondary);color:var(--text-main)}.preview-modal-content{flex:1;overflow-y:auto;border:1px solid var(--border-color);border-radius:12px;min-height:200px}.preview-modal-empty{padding:60px 40px;text-align:center;color:var(--text-sub);font-size:1rem}.preview-table{width:100%;border-collapse:collapse;font-size:.9rem}.preview-table th,.preview-table td{border-bottom:1px solid var(--border-color);padding:12px;text-align:left;vertical-align:top}.preview-table th{background:var(--bg-tertiary);color:var(--text-sub);font-weight:600;position:sticky;top:0;z-index:1}.preview-table tr:last-child td{border-bottom:none}.preview-table tr:hover{background:var(--bg-tertiary)}.word-cell{min-width:100px}.word-cell strong{display:block;color:var(--text-main);font-size:1rem}.word-cell .phonetic{display:block;font-size:.8rem;color:var(--text-sub);font-family:monospace;margin-top:2px}.meaning-cell{max-width:250px}.meaning-cell .pos{color:var(--primary);font-weight:600;margin-right:4px;font-size:.8rem}.note-cell{vertical-align:top}.note-editor{width:100%;min-height:48px;resize:vertical;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-main);font-size:.85rem;padding:6px 8px;font-family:inherit;transition:border-color .2s}.note-editor:focus{outline:none;border-color:var(--primary)}.note-editor::placeholder{color:var(--text-sub)}.mistake-cell{color:var(--danger);font-weight:700;text-align:center;min-width:60px}.preview-modal-footer{margin-top:20px;padding-top:15px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center}.preview-count{font-size:.9rem;color:var(--text-sub)}.preview-export-btn{padding:12px 24px;background:var(--success);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px}.preview-export-btn:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.preview-export-btn:disabled{background:#94a3b8;cursor:not-allowed}@media(max-width:640px){.preview-modal{width:100%;height:100%;max-height:100%;border-radius:0;padding:16px}.preview-table th,.preview-table td{padding:10px 8px;font-size:.85rem}.note-cell{display:none}}.change-password-modal{background:var(--bg-secondary);border-radius:16px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border-color);animation:modalSlideIn .2s ease-out}.change-password-form{padding:24px}.change-password-form .form-group{margin-bottom:20px}.change-password-form label{display:block;font-size:.9rem;font-weight:500;color:var(--text-main);margin-bottom:8px}.change-password-form input{width:100%;padding:12px 16px;font-size:1rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-main);color:var(--text-main);transition:all .2s;box-sizing:border-box}.change-password-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.change-password-form input::placeholder{color:var(--text-sub);opacity:.7}.change-password-form input:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.edit-profile-modal{background:var(--bg-secondary);border-radius:16px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d;border:1px solid var(--border-color);animation:modalSlideIn .2s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-main)}.modal-close-btn{background:none;border:none;font-size:1.2rem;color:var(--text-sub);cursor:pointer;padding:4px 8px;border-radius:6px;transition:all .2s}.modal-close-btn:hover{background:var(--bg-tertiary);color:var(--text-main)}.edit-profile-form{padding:24px}.edit-profile-form .form-group{margin-bottom:20px}.edit-profile-form label{display:block;font-size:.9rem;font-weight:500;color:var(--text-main);margin-bottom:8px}.edit-profile-form input{width:100%;padding:12px 16px;font-size:1rem;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-main);color:var(--text-main);transition:all .2s;box-sizing:border-box}.edit-profile-form input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.edit-profile-form input::placeholder{color:var(--text-sub);opacity:.7}.edit-profile-form input:disabled{opacity:.6;cursor:not-allowed}.form-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:10px;font-size:.9rem;margin-bottom:20px}.form-success{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#22c55e;padding:12px 16px;border-radius:10px;font-size:.9rem;margin-bottom:20px}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions .btn-cancel{flex:1;padding:12px 20px;font-size:1rem;font-weight:500;border:1px solid var(--border-color);border-radius:10px;background:var(--bg-tertiary);color:var(--text-main);cursor:pointer;transition:all .2s}.form-actions .btn-cancel:hover:not(:disabled){background:var(--bg-hover)}.form-actions .btn-submit{flex:1;padding:12px 20px;font-size:1rem;font-weight:500;border:none;border-radius:10px;background:var(--primary);color:#fff;cursor:pointer;transition:all .2s}.form-actions .btn-submit:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.form-actions button:disabled{opacity:.6;cursor:not-allowed;transform:none}.sidebar{width:100%;height:100%;background:linear-gradient(180deg,var(--bg-secondary) 0%,var(--bg) 100%);display:flex;flex-direction:column;overflow:hidden;z-index:100;transition:background .3s,border-color .3s}@media(min-width:1025px){.sidebar{position:fixed;top:0;bottom:0;height:100vh}.sidebar-left{left:0;border-right:1px solid var(--border-color);border-left:none;box-shadow:2px 0 8px #00000008}.sidebar-right{right:0;border-left:1px solid var(--border-color);border-right:none;box-shadow:-2px 0 8px #00000008}}.sidebar-resize-handle{position:absolute;top:0;bottom:0;width:12px;cursor:col-resize;background:transparent;z-index:200;transition:background .2s}.sidebar-left .sidebar-resize-handle{right:-4px}.sidebar-right .sidebar-resize-handle{left:-4px}.sidebar-resize-handle:after{content:"";position:absolute;left:50%;top:0;bottom:0;width:4px;transform:translate(-50%);background:transparent;transition:background .2s}.sidebar-resize-handle:hover:after{background:var(--primary);opacity:.6}.sidebar-resize-handle.active:after{background:var(--primary);opacity:1}.sidebar-header{flex-shrink:0;padding:24px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);z-index:10}.sidebar-scroll{flex:1;overflow-y:auto;overflow-x:hidden;padding:12px 16px 16px}.sidebar-scroll::-webkit-scrollbar{width:6px}.sidebar-scroll::-webkit-scrollbar-track{background:transparent}.sidebar-scroll::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.sidebar-scroll::-webkit-scrollbar-thumb:hover{background:#0000004d}.logo{font-size:1.5rem;font-weight:800;color:var(--text-main);margin:0 0 16px;display:flex;align-items:center;gap:8px}.current-slot-info{background:var(--bg-tertiary);padding:12px;border-radius:12px;margin-top:12px;border:1px solid var(--border-color)}.slot-name{font-size:.95rem;font-weight:600;color:var(--primary);margin-bottom:4px}.slot-stats-mini{font-size:.85rem;color:var(--text-sub)}.sidebar-header-actions{margin-top:12px;display:flex;gap:8px;flex-wrap:wrap}.sidebar-header-btn{padding:6px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-tertiary);font-size:.8rem;color:var(--text-sub);cursor:pointer;transition:all .2s;font-weight:500;white-space:nowrap}.sidebar-header-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary);transform:translateY(-1px);box-shadow:0 2px 8px #4f46e54d}.sidebar-section{margin-bottom:16px}.sidebar-section-header{position:sticky;top:0;z-index:5;background:var(--bg-secondary);padding:12px 0;margin-bottom:8px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;border-radius:8px;transition:background .2s;-webkit-user-select:none;user-select:none}.sidebar-section-header:hover{background:var(--bg-tertiary)}.sidebar-section--saves .sidebar-section-header{background:linear-gradient(135deg,#4f46e514,#4f46e508);border:1px solid rgba(79,70,229,.15);padding:12px;box-shadow:0 2px 4px #4f46e514}.sidebar-section--saves .sidebar-section-header:hover{background:linear-gradient(135deg,#4f46e51f,#4f46e50d);border-color:#4f46e540}.sidebar-section-title{font-size:.9rem;font-weight:700;color:var(--text-main);margin:0;display:flex;align-items:center;gap:8px}.badge{display:inline-flex;align-items:center;justify-content:center}.badge-count{background:var(--primary);color:#fff;font-size:.75rem;font-weight:700;padding:2px 8px;border-radius:12px;min-width:20px;text-align:center}.section-toggle{font-size:.8rem;color:var(--text-sub);transition:transform .2s;display:inline-block}.nav-list{display:flex;flex-direction:column;max-height:500px;overflow:visible;transition:max-height .3s ease-out,opacity .3s}.nav-list.collapsed{max-height:0;opacity:0;overflow:hidden}.nav-item{width:100%;display:flex;align-items:center;gap:12px;padding:14px 16px;border:none;background:transparent;border-radius:12px;cursor:pointer;transition:all .2s;margin-bottom:8px;color:var(--text-main);font-weight:600;font-size:.95rem}.nav-item:last-child{margin-bottom:0}.nav-item:hover:not(:disabled){background:var(--bg-tertiary);transform:translate(2px)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 6px -1px #4f46e54d}.nav-item:disabled{opacity:.4;cursor:not-allowed}.nav-icon{font-size:1.3rem}.nav-label{flex:1;text-align:left}.export-section{padding:12px 12px 20px}.manage-list{display:flex;flex-direction:column;max-height:500px;overflow:visible;transition:max-height .3s ease-out,opacity .3s}.manage-list.collapsed{max-height:0;opacity:0;overflow:hidden}.export-btn{width:100%;display:flex;align-items:center;gap:12px;padding:12px 16px;border:2px solid var(--border-color);background:var(--bg-secondary);border-radius:10px;cursor:pointer;transition:all .2s;margin-bottom:12px;color:var(--text-main);font-weight:600;font-size:.9rem}.export-btn:last-child{margin-bottom:0}.export-btn:hover:not(:disabled){border-color:var(--primary);background:var(--bg-tertiary);transform:translate(2px)}.export-btn:disabled{opacity:.4;cursor:not-allowed}.export-btn .btn-icon{font-size:1.2rem}.export-btn .btn-label{flex:1;text-align:left}.export-btn.reset-btn{border-color:var(--warning);color:var(--warning)}.export-btn.reset-btn:hover:not(:disabled){background:#f59e0b1a;border-color:var(--warning)}.export-btn.reset-btn.confirm{background:var(--warning);color:#fff;border-color:var(--warning);animation:pulse .5s ease-in-out infinite alternate}@keyframes pulse{0%{opacity:.8}to{opacity:1}}.save-slots-section{flex:1;padding:12px 12px 20px;overflow-y:auto;display:flex;flex-direction:column}.section-title{font-size:.85rem;font-weight:700;color:var(--text-sub);margin:0 0 14px 8px;text-transform:uppercase;letter-spacing:.5px}.section-header{display:flex;align-items:center;justify-content:space-between;cursor:pointer;padding:10px 8px;margin:0 0 14px;border-radius:8px;transition:background .2s}.section-header:hover{background:var(--bg-tertiary)}.section-header .section-title{margin:0}.section-toggle{font-size:.9rem;color:var(--text-sub);transition:transform .3s}.section-toggle.collapsed{transform:rotate(-90deg)}.save-slots-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;max-height:2000px;overflow:visible;transition:max-height .3s ease-out,opacity .3s,margin-bottom .3s}.save-slots-list.collapsed{max-height:0;opacity:0;margin-bottom:0;overflow:hidden}.save-slot-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s;text-align:left}.save-slot-item:hover{border-color:var(--primary);transform:translate(2px);box-shadow:0 2px 8px #4f46e51a}.save-slot-item.active{border-color:var(--primary);background:var(--bg-tertiary);box-shadow:0 2px 8px #4f46e533}.slot-icon{width:40px;height:40px;border-radius:10px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:1.5rem;flex-shrink:0}.slot-icon img{width:100%;height:100%;border-radius:10px;object-fit:cover}.slot-info{flex:1;min-width:0}.slot-title{font-size:.9rem;font-weight:600;color:var(--text-main);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slot-progress{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.progress-text{font-size:.8rem;color:var(--text-sub);font-weight:600}.progress-detail{font-size:.7rem;color:var(--text-sub);opacity:.8}.slot-delete-btn{width:32px;height:32px;border-radius:8px;border:none;background:transparent;color:var(--text-sub);font-size:.9rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0;opacity:0}.save-slot-item:hover .slot-delete-btn{opacity:1}.slot-delete-btn:hover{background:#ef44441a;color:var(--danger)}.slot-delete-btn.confirm{opacity:1;background:var(--danger);color:#fff;font-size:.7rem;font-weight:700;width:auto;padding:0 8px;animation:shake .3s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-2px)}75%{transform:translate(2px)}}.btn-add-slot{width:100%;padding:12px;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:12px;color:var(--text-sub);font-weight:600;cursor:pointer;transition:all .2s;font-size:.9rem}.btn-add-slot:hover{border-color:var(--primary);color:var(--primary);background:var(--bg-tertiary)}.create-slot-form{width:100%;padding:12px;background:var(--card-bg);border:2px solid var(--primary);border-radius:12px;display:flex;flex-direction:column;gap:8px}.slot-name-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:.9rem;outline:none;transition:border-color .2s,background .2s;background:var(--bg-secondary);color:var(--text-main)}.slot-name-input:focus{border-color:var(--primary)}.slot-name-input::placeholder{color:var(--text-sub)}.form-actions{display:flex;gap:8px}.btn-confirm,.btn-cancel{flex:1;padding:8px;border:none;border-radius:8px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s}.btn-confirm{background:var(--success);color:#fff}.btn-confirm:hover{background:#059669}.btn-cancel{background:var(--bg-tertiary);color:var(--text-sub)}.btn-cancel:hover{background:var(--bg-secondary);border:1px solid var(--border-color)}.sidebar-footer{flex-shrink:0;padding:16px 20px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;align-items:stretch;gap:10px;background:var(--bg-secondary)}.cloud-sync-section{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-tertiary);border-radius:10px;border:1px solid var(--border-color)}.user-info{display:flex;align-items:center;justify-content:space-between;gap:8px}.user-email{font-size:.85rem;color:var(--text-main);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.btn-logout{padding:4px 10px;font-size:.75rem;font-weight:600;color:var(--text-sub);background:transparent;border:1px solid var(--border-color);border-radius:6px;cursor:pointer;transition:all .2s;flex-shrink:0}.btn-logout:hover{color:var(--danger);border-color:var(--danger);background:#ef44441a}.btn-sync{width:100%;padding:8px 12px;font-size:.85rem;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%);border:none;border-radius:8px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px}.btn-sync:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #4f46e566}.btn-sync:disabled{opacity:.7;cursor:not-allowed;background:var(--text-sub)}.offline-indicator{display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;font-size:.85rem;color:var(--text-sub);background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:8px}.user-profile-card{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.user-profile-header{display:flex;align-items:center;gap:12px;padding:12px;cursor:pointer;transition:background .2s}.user-profile-header:hover{background:var(--bg-secondary)}.user-avatar{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-icon{font-size:1.5rem}.avatar-icon.cloud{background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.user-details{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.user-name{font-size:.9rem;font-weight:600;color:var(--text-main);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-status{font-size:.75rem;font-weight:500}.user-status.online{color:var(--success)}.user-status.offline{color:var(--text-sub)}.user-menu-toggle{font-size:.8rem;color:var(--text-sub);transition:transform .2s;flex-shrink:0}.user-menu-toggle.open{transform:rotate(180deg)}.user-menu{border-top:1px solid var(--border-color);padding:12px;display:flex;flex-direction:column;gap:10px;animation:slideDown .2s ease-out}.user-menu-info{background:var(--bg-secondary);border-radius:8px;padding:10px}.menu-info-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0}.menu-info-row:not(:last-child){border-bottom:1px solid var(--border-color);padding-bottom:8px;margin-bottom:4px}.info-label{font-size:.75rem;color:var(--text-sub);font-weight:500}.info-value{font-size:.8rem;color:var(--text-main);font-weight:500;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.offline-hint{font-size:.8rem;color:var(--text-sub);line-height:1.5;margin:0}.user-menu-btn{width:100%;display:flex;align-items:center;gap:10px;padding:10px 12px;border:none;border-radius:8px;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s}.user-menu-btn .btn-icon{font-size:1rem}.user-menu-btn .btn-text{flex:1;text-align:left}.user-menu-btn.sync{background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%);color:#fff}.user-menu-btn.sync:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #4f46e566}.user-menu-btn.sync:disabled{opacity:.7;cursor:not-allowed}.user-menu-btn.logout{background:var(--bg-secondary);color:var(--text-main);border:1px solid var(--border-color)}.user-menu-btn.logout:hover:not(:disabled){background:#ef44441a;border-color:var(--danger);color:var(--danger)}.user-menu-btn.login{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.user-menu-btn.login:hover{transform:translateY(-1px);box-shadow:0 4px 12px #10b98166}.footer-buttons{display:flex;flex-direction:column;gap:8px;width:100%}.theme-toggle-btn{width:100%;padding:10px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-main);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.theme-toggle-btn:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.accent-picker{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:10px 0}.accent-dot{width:20px;height:20px;border-radius:999px;border:2px solid transparent;cursor:pointer;padding:0;background:transparent;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;position:relative}.accent-dot:after{content:"";position:absolute;inset:0;border-radius:999px;opacity:0;transition:opacity .2s ease}.accent-dot:hover{transform:scale(1.15)}.accent-dot:focus-visible{outline:2px solid var(--primary);outline-offset:3px}.accent-dot.active{transform:scale(1.2);box-shadow:0 0 0 3px var(--bg-tertiary),0 0 8px #0003;border-color:#ffffff4d}.accent-indigo{background:linear-gradient(135deg,#4f46e5,#818cf8)}.accent-emerald{background:linear-gradient(135deg,#10b981,#34d399)}.accent-rose{background:linear-gradient(135deg,#e11d48,#fb7185)}.accent-amber{background:linear-gradient(135deg,#f59e0b,#fbbf24)}.app-version{font-size:.75rem;color:var(--text-sub);text-align:center}.visit-stats{display:flex;align-items:center;justify-content:center;gap:16px;padding:10px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;font-size:.8rem;color:var(--text-sub)}.visit-stat-item{display:flex;align-items:center;gap:4px}.visit-stat-item .stat-icon{font-size:.9rem}.visit-stat-item .stat-text{font-weight:500}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--text-sub);border-radius:3px;opacity:.5}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--text-main)}@media(max-width:1024px){.sidebar{position:static;border:none;width:100%!important}.sidebar-resize-handle{display:none}.sidebar-section-header{padding:10px 8px;font-size:.85rem}.badge-count{font-size:.7rem;padding:1px 6px}.sidebar-scroll{padding:10px 12px}.sidebar-section--saves .sidebar-section-header{padding:10px}.btn-text-desktop{display:none}.btn-text-mobile{display:inline;font-size:1.2rem;line-height:1}.desktop-only{display:none!important}.sidebar-header-btn.close-btn{padding:8px 16px;background:transparent;border:none;font-size:1.5rem;color:var(--text-main)}}@media(min-width:1025px){.btn-text-mobile{display:none}.btn-text-desktop{display:inline}.desktop-only{display:inline-block}}.word-card-container{width:100%;max-width:640px;margin:0 auto}.word-card{perspective:1200px;width:100%;height:420px;margin-bottom:25px;position:relative}.word-card>div:first-child{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .4s cubic-bezier(.4,0,.2,1);cursor:pointer}.word-card.flipped>div:first-child{transform:rotateY(180deg)}.card-face{position:absolute;width:100%;height:100%;backface-visibility:hidden;background:var(--card-bg);border-radius:24px;box-shadow:var(--card-shadow);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:36px;border:1px solid var(--border-color);transition:background .3s,border-color .3s}.card-back{transform:rotateY(180deg);justify-content:flex-start;overflow-y:auto}.word-main{text-align:center;width:100%}.word-text{font-size:3.5rem;font-weight:800;color:var(--text-main);margin:0 0 18px;line-height:1.1;text-align:center}.phonetic{font-size:1.3rem;color:#94a3b8;font-family:monospace;margin-bottom:28px;text-align:center}.speak-btn{background:var(--bg-tertiary);border:none;width:48px;height:48px;border-radius:50%;font-size:1.5rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;margin-top:10px}.speak-btn:hover{background:var(--primary);transform:scale(1.1)}.speak-btn:hover:after{content:""}.speak-btn.speaking{background:var(--primary);animation:pulse 1s infinite}.speak-btn.small{width:36px;height:36px;font-size:1.2rem;margin-top:0;margin-left:10px}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}.word-header-back{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;margin-bottom:5px}.card-front .category-badge{position:absolute;top:25px;right:25px;background:var(--bg-tertiary);color:var(--primary);padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:700;letter-spacing:.5px;border:1px solid var(--border-color)}.word-meta .category-badge{position:static;background:var(--bg-tertiary);color:var(--primary);padding:6px 12px;border-radius:20px;font-size:.8rem;font-weight:700;letter-spacing:.5px;border:1px solid var(--border-color)}.fav-btn{position:absolute;top:20px;left:20px;font-size:1.8rem;color:#e2e8f0;cursor:pointer;z-index:10;background:none;border:none;padding:5px;transition:transform .2s,color .2s}.fav-btn:active{transform:scale(1.2)}.fav-btn.active{color:#f43f5e}.mistake-indicator{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--danger);font-weight:600;margin-bottom:10px;opacity:0;background:#ef44441a;padding:4px 10px;border-radius:20px;transition:opacity .3s}.mistake-indicator.visible{opacity:1}.flip-hint{font-size:1.15rem;color:#94a3b8;font-family:monospace;margin-top:24px;text-align:center}.word-text-small{font-size:1.6rem;font-weight:700;color:var(--primary);margin:0 0 20px;text-align:center;width:100%}.phonetic-small{font-size:1rem;color:#94a3b8;font-family:monospace;margin-bottom:15px;text-align:center}.meanings{width:100%;margin-bottom:15px}.meaning-item{margin-bottom:.8rem;display:flex;gap:.5rem;align-items:baseline}.part-of-speech{color:var(--primary);font-weight:600;font-size:.85rem;flex-shrink:0}.definition{color:var(--text-main);line-height:1.5;font-size:1rem}.examples{background:var(--bg-tertiary);padding:12px;border-radius:12px;margin-bottom:15px;width:100%;border:1px solid var(--border-color)}.examples h3{margin:0 0 8px;font-size:.9rem;color:var(--text-sub);font-weight:600}.example{margin:6px 0;color:var(--text-sub);line-height:1.5;font-style:italic;font-size:.9rem}.note-area{width:100%;margin-top:10px;text-align:left}.note-input{width:100%;border:2px solid var(--border-color);background:var(--bg-tertiary);border-radius:12px;padding:12px;font-size:.95rem;resize:none;height:80px;font-family:inherit;transition:border-color .2s,background .2s;color:var(--text-main)}.note-input:focus{border-color:var(--primary);background:var(--bg-secondary)}.note-input::placeholder{color:var(--text-sub)}.word-meta{display:flex;gap:1rem;align-items:center;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border-color);width:100%}.difficulty{color:var(--warning);font-size:.9rem}.card-actions{display:flex;gap:15px;width:100%;max-width:500px;margin:0 auto}.action-btn{flex:1;padding:18px;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .1s;display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;box-shadow:0 10px 15px -3px #0000001a}.action-btn:active{transform:scale(.96)}.action-btn:disabled{opacity:.6;cursor:not-allowed}.btn-dont-know{background:var(--danger)}.btn-dont-know:hover:not(:disabled){background:#dc2626}.btn-next{background:var(--bg-secondary);color:var(--text-sub);border:2px solid var(--border-color);box-shadow:none;flex:0 0 65px;font-size:1.5rem;padding:0;transition:background .2s,border-color .2s}.btn-next:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary)}.btn-know{background:var(--success)}.btn-know:hover:not(:disabled){background:#059669}@media(max-width:768px){.word-card-container{max-width:100%}.word-card{height:380px}.word-text{font-size:2.8rem}.phonetic{font-size:1.1rem}.card-face{padding:28px}}@media(max-width:480px){.word-text{font-size:2.4rem}.phonetic{font-size:1rem}.word-card{height:340px}.card-face{padding:20px}.action-btn{padding:15px;font-size:1rem}.flip-hint{font-size:1rem}}.card-back::-webkit-scrollbar{width:6px}.card-back::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.card-back::-webkit-scrollbar-thumb{background:var(--text-sub);border-radius:3px;opacity:.5}.card-back::-webkit-scrollbar-thumb:hover{background:var(--text-main)}.learn-page{width:100%;max-width:1200px;margin:0 auto;padding:0;min-height:100vh;background-color:transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.header-bar{background:var(--card-bg);padding:1rem 1.5rem;display:flex;align-items:center;gap:1.5rem;box-shadow:0 2px 8px #0000000d;margin-bottom:20px;width:100%;max-width:1200px;border-radius:16px;border:1px solid var(--border-color);transition:background .3s,border-color .3s}.btn-back{background:transparent;border:none;font-size:.95rem;color:var(--primary);cursor:pointer;padding:.5rem 1rem;border-radius:8px;transition:background .2s;font-weight:600}.btn-back:hover{background:var(--bg-tertiary)}.header-bar h2{margin:0;flex:1;color:var(--text-main);font-size:1.3rem;font-weight:800}.header-actions{display:flex;align-items:center;gap:12px}.progress-info{font-size:1rem;color:var(--text-sub);font-weight:600}.btn-refresh{width:36px;height:36px;border-radius:50%;border:2px solid var(--border-color);background:var(--bg-secondary);font-size:1rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-refresh:hover{border-color:var(--primary);background:var(--bg-tertiary);transform:rotate(90deg)}.btn-refresh:active{transform:rotate(180deg)}.tabs{display:flex;gap:10px;margin-bottom:20px;overflow-x:auto;width:100%;max-width:1200px;padding:0 0 5px;scrollbar-width:none;justify-content:center;flex-wrap:wrap}.tabs::-webkit-scrollbar{display:none}.tab{white-space:nowrap;padding:8px 16px;border-radius:20px;background:var(--bg-secondary);color:var(--text-sub);border:1px solid var(--border-color);font-size:.9rem;cursor:pointer;font-weight:600;transition:all .2s}.tab:hover{background:var(--bg-tertiary);border-color:var(--primary);color:var(--primary)}.tab.active{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:0 4px 6px -2px #4f46e54d}.dashboard{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;width:100%;max-width:900px;margin-bottom:25px;padding:0}.stat-card{background:var(--card-bg);padding:20px 10px;border-radius:16px;text-align:center;box-shadow:0 4px 6px -1px #0000000d;transition:transform .2s,background .3s;border:1px solid var(--border-color)}.stat-card:hover{transform:translateY(-2px);box-shadow:0 6px 8px -1px #0000001a}.stat-num{display:block;font-size:1.8rem;font-weight:800;margin-bottom:8px;line-height:1}.stat-label{font-size:.85rem;color:var(--text-sub);font-weight:500}.stats-bar{display:flex;gap:2rem;justify-content:center;padding:12px 1.5rem;background:var(--card-bg);margin:0 0 25px;border-radius:12px;box-shadow:0 2px 8px #0000000d;width:100%;max-width:900px;border:1px solid var(--border-color);transition:background .3s,border-color .3s}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-label{font-size:.8rem;color:var(--text-sub);font-weight:500}.stat-value{font-size:1.3rem;font-weight:700;color:var(--primary)}.stat-value.correct{color:var(--success)}.stat-value.wrong{color:var(--danger)}.empty-state{text-align:center;padding:4rem 2rem}.empty-state h2{font-size:2rem;margin-bottom:1rem;color:var(--text-main)}.empty-state p{font-size:1.1rem;color:var(--text-sub);margin-bottom:2rem}.session-summary{display:flex;gap:2rem;justify-content:center;margin-top:2rem;padding:2rem;background:var(--card-bg);border-radius:12px;box-shadow:0 4px 12px #00000014;max-width:500px;margin-left:auto;margin-right:auto;border:1px solid var(--border-color)}.summary-item{display:flex;flex-direction:column;align-items:center;gap:.5rem}.summary-item .label{font-size:.9rem;color:var(--text-sub)}.summary-item .value{font-size:2rem;font-weight:700;color:var(--primary)}.summary-item .value.correct{color:var(--success)}.summary-item .value.wrong{color:var(--danger)}.session-actions{margin-top:2rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-continue{padding:14px 32px;font-size:1.1rem;border-radius:12px;border:none;cursor:pointer;font-weight:700;transition:all .2s}.btn-primary{background:var(--primary);color:#fff;box-shadow:0 4px 12px #4f46e54d}.btn-primary:hover{background:#4338ca;transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}.btn-secondary{background:var(--bg-secondary);color:var(--text-main);border:2px solid var(--border-color);padding:12px 24px;font-size:1rem;border-radius:10px;cursor:pointer;font-weight:600;transition:all .2s}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--primary);color:var(--primary)}.smart-mode-switch{min-width:260px;max-width:380px;padding:18px 24px;border-radius:16px;border:2px solid var(--border-color);background:var(--card-bg);box-shadow:0 4px 16px #0000000f;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;cursor:pointer;text-align:center;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.smart-mode-title{font-size:1rem;font-weight:700;color:var(--primary);line-height:1.3}.smart-mode-hint{font-size:.8rem;line-height:1.5;color:var(--text-sub);max-width:320px}.smart-mode-switch:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f;border-color:var(--primary);background:linear-gradient(135deg,var(--card-bg) 0%,var(--bg-tertiary) 100%)}.smart-mode-switch:active{transform:translateY(0);box-shadow:0 4px 12px #00000014}.smart-mode-switch:disabled{opacity:.5;cursor:not-allowed;transform:none}.session-complete h2{font-size:2.5rem}.session-complete p{font-size:1.2rem;color:var(--text-sub)}@media(max-width:768px){.learn-page{justify-content:flex-start;padding-top:20px;gap:12px}.header-bar{padding:.8rem 1rem;margin-bottom:15px}.header-bar h2{font-size:1.1rem}.progress-info{font-size:.9rem}.btn-refresh{width:32px;height:32px;font-size:.9rem}.tabs{gap:8px;justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin}.tabs::-webkit-scrollbar{height:4px}.tabs::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:2px}.tab{font-size:.85rem;padding:6px 12px;flex-shrink:0}.dashboard{gap:8px;max-width:100%}.stat-card{padding:12px 4px}.stat-num{font-size:1.5rem;margin-bottom:6px}.stats-bar{gap:1rem;padding:10px 1rem;max-width:100%}.stat-value{font-size:1.2rem}.stat-label{font-size:.75rem}.control-area{margin-top:15px;max-width:100%}.shortcut-hints,.btn-key-hint{display:none}.btn-text{font-size:1rem}}@media(max-width:480px){.learn-page{gap:10px}.dashboard{gap:6px}.stat-card{padding:10px 2px}.stat-num{font-size:1.3rem}.tabs{gap:6px}.tab{font-size:.8rem;padding:5px 10px}.header-bar{padding:.7rem .8rem}.header-bar h2{font-size:1rem}.progress-info{font-size:.85rem}.stats-bar{gap:.75rem;padding:8px .8rem}.stat-value{font-size:1.1rem}.stat-label{font-size:.7rem}.control-area{margin-top:12px}.btn{padding:14px;font-size:1rem}.btn-text{font-size:.95rem}}.control-area{width:100%;max-width:640px;display:flex;flex-direction:column;gap:15px;padding:0;margin-top:20px}.main-actions{display:flex;gap:15px}.history-nav{display:flex;gap:15px;width:100%}.btn{flex:1;padding:18px;border:none;border-radius:16px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:transform .1s;display:flex;align-items:center;justify-content:center;gap:8px;color:#fff;box-shadow:0 10px 15px -3px #0000001a}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-back-arrow{background:var(--bg-secondary);color:var(--text-sub);border:2px solid var(--border-color);box-shadow:none;flex:0 0 65px;font-size:1.5rem;padding:0;transition:background .2s,border-color .2s}.btn-back-arrow:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--primary)}.btn-danger{background:var(--danger)}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-success{background:var(--success)}.btn-success:hover:not(:disabled){background:#059669}.btn-nav{background:var(--primary);flex:1}.btn-nav:hover:not(:disabled){background:#4338ca}.shortcut-hints{margin-top:12px;text-align:center;width:100%;max-width:600px;color:var(--text-sub);font-size:.85rem;opacity:.85;padding:0 10px}.shortcut-hint{display:inline-flex;align-items:center;gap:4px;flex-wrap:wrap;justify-content:center}.shortcut-hint kbd{padding:3px 8px;border-radius:5px;border:1px solid var(--border-color);background:var(--bg-tertiary);font-size:.75rem;font-family:Courier New,Courier,monospace;font-weight:600;color:var(--text-main);box-shadow:0 2px 4px #0000001a;transition:all .2s}.btn-key-hint{display:inline-flex;align-items:center;justify-content:center;margin:0 6px}.btn-key-hint kbd{padding:5px 10px;border-radius:7px;border:2px solid rgba(255,255,255,.6);background:#00000040;font-size:1rem;font-family:Courier New,Courier,monospace;font-weight:800;color:#fff;box-shadow:0 3px 6px #00000040,inset 0 -2px #0003;min-width:32px;text-align:center;line-height:1;letter-spacing:-.5px}.btn-text{display:inline-block;font-size:1.15rem}@keyframes btn-nod-left{0%{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(0)}75%{transform:translate(-4px)}to{transform:translate(0)}}@keyframes btn-nod-right{0%{transform:translate(0)}25%{transform:translate(4px)}50%{transform:translate(0)}75%{transform:translate(4px)}to{transform:translate(0)}}.btn-danger.nod-hint{animation:btn-nod-left .8s ease-out .5s 1}.btn-success.nod-hint{animation:btn-nod-right .8s ease-out .5s 1}@media(max-width:480px){.shortcut-hints{font-size:.75rem;margin-top:10px}.shortcut-hint kbd{padding:2px 6px;font-size:.7rem}.btn-key-hint kbd{padding:3px 6px;font-size:.8rem;min-width:24px}}.stats-page{--pie-new: #94a3b8;--pie-learning: #60a5fa;--pie-reviewing: #f59e0b;--pie-mastered: #10b981;--heatmap-0: var(--bg-tertiary);--heatmap-1: #bbf7d0;--heatmap-2: #4ade80;--heatmap-3: #16a34a;--heatmap-4: #166534}.stats-page{padding:0;max-width:1200px;margin:0 auto;min-height:100vh;background:transparent}.stats-header{background:var(--card-bg);padding:1rem 1.5rem;margin-bottom:32px;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 2px 8px #0000000d;transition:background .3s,border-color .3s}.stats-header h1{font-size:1.5rem;font-weight:800;color:var(--text-main);margin:0}.stats-subtitle{font-size:.95rem;color:var(--text-sub);margin:8px 0 0;font-weight:500}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}@media(max-width:900px){.stats-grid{grid-template-columns:1fr}}.stats-page .stat-card{background:var(--card-bg);border-radius:20px;padding:24px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);transition:background .3s,border-color .3s}.stat-card h3{font-size:1.1rem;font-weight:700;color:var(--text-main);margin:0 0 20px}.pie-chart-container{display:flex;justify-content:center;margin-bottom:24px}.pie-chart{width:180px;height:180px;border-radius:50%;position:relative;display:flex;align-items:center;justify-content:center}.pie-center{position:absolute;width:100px;height:100px;background:var(--card-bg);border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 2px 8px #0000001a}.pie-percentage{font-size:1.8rem;font-weight:800;color:var(--pie-mastered)}.pie-label{font-size:.85rem;color:var(--text-sub)}.pie-legend{display:grid;grid-template-columns:1fr 1fr;gap:12px}.legend-item{display:flex;align-items:center;gap:8px}.legend-color{width:14px;height:14px;border-radius:4px;flex-shrink:0}.legend-text{font-size:.9rem;color:var(--text-main)}.heatmap-container{display:flex;flex-direction:column;gap:12px}.heatmap-grid{display:grid;grid-template-columns:repeat(10,1fr);gap:4px}.heatmap-cell{aspect-ratio:1;border-radius:4px;cursor:pointer;transition:transform .2s}.heatmap-cell:hover{transform:scale(1.2)}.heatmap-labels{display:flex;justify-content:space-between;font-size:.75rem;color:var(--text-sub)}.heatmap-legend{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.75rem;color:var(--text-sub)}.heatmap-legend-cells{display:flex;gap:3px}.heatmap-legend-cell{width:14px;height:14px;border-radius:3px}.hardest-list{display:flex;flex-direction:column;gap:8px;max-height:350px;overflow-y:auto}.hardest-item{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:12px;transition:background .2s}.hardest-item:hover{background:var(--bg-secondary)}.hardest-rank{font-size:.85rem;font-weight:700;color:var(--text-sub);width:30px;flex-shrink:0}.hardest-info{flex:1;min-width:0}.hardest-word{font-weight:700;color:var(--text-main);margin-bottom:2px}.hardest-meaning{font-size:.85rem;color:var(--text-sub);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hardest-stats{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.mistake-count{font-size:.9rem;font-weight:600;color:var(--danger)}.active-score{font-size:.8rem;color:var(--warning)}.empty-list{text-align:center;padding:40px 20px;color:var(--text-sub)}.projection-content{display:flex;justify-content:center;gap:48px;margin-bottom:20px}.projection-stat{text-align:center}.projection-value{font-size:2.5rem;font-weight:800;color:var(--primary);line-height:1;margin-bottom:8px}.projection-label{font-size:.9rem;color:var(--text-sub)}.projection-message{text-align:center;font-size:.95rem;color:var(--text-main);margin-bottom:24px;padding:16px;background:var(--bg-tertiary);border-radius:12px}.projection-message p{margin:0}.projection-message strong{color:var(--primary)}.progress-bar-container{margin-top:16px}.progress-bar{height:12px;background:var(--bg-tertiary);border-radius:6px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--success),#34d399);border-radius:6px;transition:width .5s ease-out}.progress-text{font-size:.85rem;color:var(--text-sub);text-align:center}.stats-page .empty-state{display:flex;align-items:center;justify-content:center;min-height:60vh;text-align:center}.stats-page .empty-state h2{font-size:1.5rem;color:var(--text-sub);font-weight:600}.stats-footer{margin-top:32px;padding:16px 24px;text-align:center}.stats-note{font-size:.85rem;color:var(--text-sub);margin:0;opacity:.8}.hardest-list::-webkit-scrollbar{width:6px}.hardest-list::-webkit-scrollbar-track{background:transparent}.hardest-list::-webkit-scrollbar-thumb{background:var(--text-sub);border-radius:3px;opacity:.5}.hardest-list::-webkit-scrollbar-thumb:hover{background:var(--text-main)}.data-inconsistency-notice{display:flex;align-items:flex-start;gap:16px;padding:24px;background:linear-gradient(135deg,#fbbf241a,#f59e0b1a);border:2px solid rgba(251,191,36,.3);border-radius:12px;margin-top:16px}.notice-icon{font-size:2rem;flex-shrink:0;line-height:1}.notice-content{flex:1}.notice-content h4{margin:0 0 8px;color:var(--text-main);font-size:1rem;font-weight:700}.notice-content p{margin:0 0 8px;color:var(--text-sub);font-size:.9rem;line-height:1.5}.notice-content p:last-child{margin-bottom:0}.notice-hint{color:var(--primary)!important;font-weight:600}.quiz-page{padding:0;max-width:900px;margin:0 auto;min-height:100vh;display:flex;flex-direction:column}.quiz-header{background:var(--card-bg);padding:1rem 1.5rem;margin-bottom:32px;border-radius:16px;border:1px solid var(--border-color);box-shadow:0 2px 8px #0000000d;transition:background .3s,border-color .3s}.quiz-header h1{font-size:1.5rem;font-weight:800;color:var(--text-main);margin:0}.quiz-subtitle{font-size:.95rem;color:var(--text-sub);margin:8px 0 0;font-weight:500}.quiz-type-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}@media(max-width:640px){.quiz-type-grid{grid-template-columns:1fr}}.quiz-type-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:20px;padding:30px 20px;text-align:center;cursor:pointer;transition:all .3s}.quiz-type-card:hover{border-color:var(--primary);transform:translateY(-4px);box-shadow:0 10px 25px #4f46e526}.quiz-type-icon{font-size:3rem;display:block;margin-bottom:16px}.quiz-type-card h3{font-size:1.2rem;font-weight:700;color:var(--text-main);margin:0 0 8px}.quiz-type-card p{font-size:.9rem;color:var(--text-sub);margin:0}.quiz-stats-preview{background:var(--bg-tertiary);border-radius:16px;padding:20px;text-align:center}.quiz-stats-preview h3{font-size:.9rem;color:var(--text-sub);margin:0 0 12px;font-weight:600}.stats-row{display:flex;justify-content:center;gap:24px;font-size:.95rem;color:var(--text-main)}.quiz-progress{display:flex;align-items:center;gap:16px;margin-bottom:24px}.quiz-progress .progress-bar{flex:1;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden}.quiz-progress .progress-fill{height:100%;background:var(--primary);transition:width .3s}.quiz-progress .progress-text{font-size:.9rem;color:var(--text-sub);font-weight:600;min-width:60px;text-align:right}.quiz-card{background:var(--card-bg);border-radius:20px;padding:40px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);text-align:center;flex:1;display:flex;flex-direction:column;justify-content:center;min-height:400px}.question-word{margin-bottom:30px;display:flex;flex-direction:column;align-items:center;gap:8px}.word-display{font-size:2.5rem;font-weight:800;color:var(--text-main);margin:0}.meaning-display{font-size:1.8rem;font-weight:700;color:var(--text-main);text-align:center;margin:0;line-height:1.4}.typing-hint{font-size:.95rem;color:var(--text-sub);text-align:center;margin:0;font-weight:500}.phonetic-display{font-size:1.1rem;color:var(--text-sub);font-family:monospace;margin:0}.speak-mini-btn{background:var(--bg-tertiary);border:none;width:44px;height:44px;border-radius:50%;font-size:1.3rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #00000026}.speak-mini-btn:hover{background:var(--primary);transform:scale(1.1);box-shadow:0 4px 12px #4f46e54d}.question-listening{margin-bottom:30px}.play-btn{background:var(--primary);color:#fff;border:none;padding:20px 40px;border-radius:12px;font-size:1.3rem;font-weight:700;cursor:pointer;transition:all .2s;margin-bottom:16px;box-shadow:0 4px 12px #4f46e533}.play-btn:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e54d}.listening-hint{font-size:.95rem;color:var(--text-sub)}.options-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}@media(max-width:480px){.options-grid{grid-template-columns:1fr}}.option-btn{background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;padding:16px;font-size:1rem;color:var(--text-main);cursor:pointer;transition:all .2s;text-align:left}.option-btn:hover{border-color:var(--primary);background:var(--bg-tertiary)}.typing-area{display:flex;gap:12px;margin-top:20px}.answer-input{flex:1;padding:16px 20px;border:2px solid var(--border-color);border-radius:12px;font-size:1.1rem;background:var(--bg-secondary);color:var(--text-main);outline:none;transition:border-color .2s}.answer-input:focus{border-color:var(--primary)}.answer-input::placeholder{color:var(--text-sub)}.submit-btn{padding:16px 32px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e533}.submit-btn:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e54d}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.result-feedback{padding:20px;border-radius:12px;margin:20px 0;font-size:1.2rem;font-weight:700}.result-feedback.correct{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.2)}.result-feedback.wrong{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2)}.correct-answer{margin-top:10px;font-size:1rem;font-weight:600}.next-btn{margin-top:20px;padding:16px 40px;background:var(--success);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #10b98133}.next-btn:hover{background:#059669;transform:translateY(-1px);box-shadow:0 6px 16px #10b9814d}.quit-btn{margin-top:20px;padding:12px 24px;background:transparent;color:var(--text-sub);border:2px solid var(--border-color);border-radius:12px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;align-self:center}.quit-btn:hover{border-color:var(--danger);color:var(--danger)}.quiz-result{text-align:center;flex:1;display:flex;flex-direction:column;justify-content:center;align-items:center}.result-icon{font-size:5rem;margin-bottom:20px}.quiz-result h2{font-size:1.8rem;font-weight:800;color:var(--text-main);margin:0 0 20px}.result-grade{width:100px;height:100px;border-radius:50%;background:var(--primary);color:#fff;font-size:3rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:20px}.result-score{font-size:1.5rem;font-weight:700;color:var(--text-main);margin-bottom:8px}.result-percentage{font-size:1.2rem;color:var(--text-sub);margin-bottom:30px}.result-actions{display:flex;gap:16px}.btn-restart{padding:14px 28px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e533}.btn-restart:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e54d}.btn-back{padding:14px 28px;background:transparent;color:var(--text-main);border:2px solid var(--border-color);border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-back:hover{border-color:var(--primary);color:var(--primary);background:#4f46e50a}.quiz-page .empty-state{flex:1;display:flex;align-items:center;justify-content:center}.quiz-page .empty-state h2{font-size:1.5rem;color:var(--text-sub);font-weight:600}.login-page{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg)}.login-content{display:grid;grid-template-columns:1.2fr 1fr;gap:0;width:100%;max-width:1200px;height:100vh;max-height:900px;box-shadow:0 20px 60px #00000026;border-radius:24px;overflow:hidden;background:var(--card-bg)}.login-hero{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;background:linear-gradient(135deg,var(--primary) 0%,var(--primary-hover) 100%);overflow:hidden}.hero-image{width:100%;height:100%;position:absolute;top:0;left:0;background-size:cover;background-position:center;background-repeat:no-repeat;opacity:.85;z-index:0}.hero-caption{position:relative;z-index:1;text-align:center;color:#fff;margin-top:auto;padding:2rem;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;border:1px solid rgba(255,255,255,.2)}.hero-caption h2{font-size:1.8rem;font-weight:800;margin:0 0 .5rem;text-shadow:0 2px 8px rgba(0,0,0,.3)}.hero-caption p{font-size:1rem;margin:0;opacity:.95;font-weight:500}.login-form-section{display:flex;align-items:center;justify-content:center;padding:2rem;overflow-y:auto;background:var(--card-bg)}.login-card{width:100%;max-width:420px;animation:fadeInUp .4s ease-out forwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;margin-bottom:2rem}.login-title{font-size:2rem;font-weight:800;color:var(--text-main);margin:0 0 .5rem;letter-spacing:-.01em}.login-subtitle{font-size:.95rem;font-weight:400;color:var(--text-sub);margin:0}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-input{width:100%;height:48px;padding:0 1rem;font-size:1rem;color:var(--text-main);background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;outline:none;box-sizing:border-box;transition:all .2s}.form-input::placeholder{color:var(--text-sub);opacity:.6}.form-input:focus{border-color:var(--primary);background:var(--card-bg)}.form-input:hover:not(:focus){border-color:var(--text-sub)}.login-error{padding:.875rem 1rem;font-size:.9rem;color:var(--danger);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:12px;display:flex;align-items:flex-start;gap:.5rem}.login-error:before{content:"⚠";flex-shrink:0;font-size:1.1rem}.login-success{padding:.875rem 1rem;font-size:.9rem;color:var(--success);background:#10b98114;border:1px solid rgba(16,185,129,.2);border-radius:12px;display:flex;align-items:flex-start;gap:.5rem}.login-success:before{content:"✓";flex-shrink:0;font-size:1.1rem;font-weight:700}.button-group{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.btn-login{width:100%;height:48px;padding:0 1.5rem;font-size:1rem;font-weight:700;color:#fff;background:var(--primary);border:none;border-radius:12px;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e533}.btn-login:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e54d}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-register{width:100%;height:44px;padding:0 1rem;font-size:.95rem;font-weight:600;color:var(--text-main);background:transparent;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s}.btn-register:hover:not(:disabled){border-color:var(--primary);color:var(--primary);background:#4f46e50a}.btn-register:active:not(:disabled){transform:scale(.98)}.btn-register:disabled{opacity:.5;cursor:not-allowed}.login-divider{display:flex;align-items:center;margin:1.5rem 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.login-divider span{padding:0 1rem;color:var(--text-sub);font-size:.85rem;font-weight:500}.btn-offline{width:100%;height:44px;padding:0 1rem;font-size:.9rem;font-weight:600;color:var(--text-sub);background:var(--bg-tertiary);border:1px dashed var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s}.btn-offline:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--text-sub);color:var(--text-main)}.btn-offline:disabled{opacity:.5;cursor:not-allowed}.login-footer{margin-top:1.75rem;text-align:center}.login-hint{font-size:.85rem;color:var(--text-sub);margin:0;line-height:1.6}.login-link{color:var(--primary);text-decoration:none;font-weight:500;transition:opacity .2s}.login-link:hover{opacity:.8;text-decoration:underline}@media(max-width:1024px){.login-page{position:relative;height:auto;min-height:100vh;align-items:flex-start;background:var(--bg-secondary);overflow-y:auto}.login-content{display:flex;flex-direction:column;max-width:100%;height:auto;max-height:none;box-shadow:none;border-radius:0;background:transparent}.login-hero{height:45vh;min-height:320px;flex-shrink:0;padding:2rem 1.5rem;justify-content:flex-end;align-items:center}.hero-image{background-position:center top;opacity:.9}.hero-caption{margin-top:auto;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.15);text-align:center;padding:.75rem 1.25rem;max-width:90%;border-radius:12px;margin-bottom:10px}.hero-caption h2{font-size:1.2rem;margin-bottom:.25rem}.hero-caption p{font-size:.85rem;opacity:.95}.login-form-section{margin-top:-20px;border-top-left-radius:24px;border-top-right-radius:24px;background:var(--card-bg);position:relative;z-index:2;box-shadow:0 -10px 25px #0000000d;padding:2rem 1.5rem 4rem;flex:1;align-items:flex-start;overflow:visible}.login-card{max-width:100%;padding:0;box-shadow:none;animation:none}.login-header{margin-bottom:1.75rem;text-align:left}.login-title{font-size:1.75rem}}@media(max-width:375px){.login-hero{height:40vh;min-height:280px}.hero-caption h2{font-size:1.1rem}.login-form-section{padding:1.5rem 1.25rem 3rem}.login-title{font-size:1.5rem}.form-input,.btn-login,.btn-register,.btn-offline{height:44px}}.password-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.forgot-password-link{background:none;border:none;color:var(--primary);font-size:.85rem;font-weight:600;cursor:pointer;padding:0;transition:opacity .2s}.forgot-password-link:hover:not(:disabled){opacity:.8;text-decoration:underline}.forgot-password-link:disabled{opacity:.5;cursor:not-allowed}.reset-dialog-backdrop{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.reset-dialog{background:var(--card-bg);border-radius:16px;padding:24px;width:90%;max-width:420px;box-shadow:0 20px 60px #0000004d;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.reset-dialog-title{font-size:1.5rem;font-weight:700;color:var(--text-main);margin:0 0 12px}.reset-dialog-description{font-size:.95rem;color:var(--text-sub);margin:0 0 20px;line-height:1.5}.reset-email-input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:10px;font-size:1rem;background:var(--bg-secondary);color:var(--text-main);transition:border-color .2s;margin-bottom:12px}.reset-email-input:focus{outline:none;border-color:var(--primary)}.reset-email-input:disabled{opacity:.6;cursor:not-allowed}.reset-error{padding:12px 16px;background:#ef44441a;border:1px solid var(--danger);border-radius:8px;color:var(--danger);font-size:.9rem;margin-bottom:16px}.reset-success{padding:12px 16px;background:#10b9811a;border:1px solid var(--success);border-radius:8px;color:var(--success);font-size:.9rem;margin-bottom:16px}.reset-dialog-actions{display:flex;gap:12px;margin-top:16px}.btn-reset-cancel,.btn-reset-submit{flex:1;padding:12px 20px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none}.btn-reset-cancel{background:var(--bg-secondary);color:var(--text-main);border:2px solid var(--border-color)}.btn-reset-cancel:hover:not(:disabled){background:var(--bg-tertiary)}.btn-reset-submit{background:var(--primary);color:#fff}.btn-reset-submit:hover:not(:disabled){background:var(--primary-hover)}.btn-reset-cancel:disabled,.btn-reset-submit:disabled{opacity:.6;cursor:not-allowed}.feedback-page{width:100%;max-width:800px;margin:0 auto;padding:20px;min-height:100vh}.feedback-container{display:flex;flex-direction:column;gap:24px}.feedback-header{text-align:center;margin-bottom:10px}.feedback-header h1{font-size:2rem;font-weight:800;color:var(--text-main);margin:0 0 8px}.feedback-subtitle{font-size:.95rem;color:var(--text-sub);margin:0;line-height:1.5}.message-box{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:12px;font-size:.95rem;font-weight:500;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.message-success{background:#10b9811a;color:var(--success);border:1px solid rgba(16,185,129,.3)}.message-error{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.message-icon{font-size:1.2rem;flex-shrink:0}.message-text{flex:1}.message-close{background:transparent;border:none;font-size:1.2rem;color:inherit;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s;flex-shrink:0}.message-close:hover{background:#0000001a}.feedback-form-card,.feedback-list-card{background:var(--card-bg);border-radius:16px;padding:24px;box-shadow:0 2px 8px #0000000d;border:1px solid var(--border-color);transition:background .3s,border-color .3s}.section-title{font-size:1.3rem;font-weight:700;color:var(--text-main);margin:0 0 20px}.feedback-form{display:flex;flex-direction:column;gap:18px}.required{color:var(--danger);margin-left:2px}.form-select,.form-input,.form-textarea{width:100%;padding:12px 14px;border:2px solid var(--border-color);border-radius:10px;font-size:.95rem;font-family:inherit;background:var(--bg-secondary);color:var(--text-main);transition:border-color .2s,background .2s;outline:none}.form-select:focus,.form-input:focus,.form-textarea:focus{border-color:var(--primary);background:var(--bg)}.form-select:disabled,.form-input:disabled,.form-textarea:disabled{opacity:.6;cursor:not-allowed}.form-textarea{resize:vertical;min-height:120px;line-height:1.6}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-sub);opacity:.7}.btn-submit{width:100%;padding:14px 20px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e54d}.btn-submit:hover:not(:disabled){background:#4338ca;transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none}.feedback-loading{display:flex;align-items:center;justify-content:center;gap:10px;padding:40px;color:var(--text-sub);font-size:.95rem}.loading-spinner{font-size:1.5rem;animation:spin 1s linear infinite}.feedback-empty-list{text-align:center;padding:40px;color:var(--text-sub)}.feedback-empty-list p{margin:0;font-size:.95rem}.feedback-list{display:flex;flex-direction:column;gap:14px}.feedback-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:16px;transition:all .2s}.feedback-item:hover{border-color:var(--primary);box-shadow:0 2px 8px #4f46e51a}.feedback-item-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.feedback-category{font-size:.85rem;font-weight:600;color:var(--primary)}.feedback-status{font-size:.75rem;font-weight:600;padding:4px 10px;border-radius:12px;white-space:nowrap}.feedback-item-content{font-size:.95rem;color:var(--text-main);line-height:1.6;margin-bottom:10px;white-space:pre-wrap;word-break:break-word}.feedback-item-contact{font-size:.85rem;color:var(--text-sub);margin-bottom:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:8px}.feedback-item-footer{display:flex;align-items:center;justify-content:flex-end}.feedback-time{font-size:.8rem;color:var(--text-sub)}.feedback-empty{text-align:center;padding:60px 20px}.empty-icon{font-size:4rem;margin-bottom:20px}.feedback-empty h2{font-size:1.8rem;font-weight:700;color:var(--text-main);margin:0 0 12px}.feedback-empty p{font-size:1rem;color:var(--text-sub);margin:0 0 24px}.btn-login{padding:12px 32px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e54d}.btn-login:hover{background:#4338ca;transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}@media(max-width:768px){.feedback-page{padding:15px}.feedback-header h1{font-size:1.6rem}.feedback-subtitle{font-size:.9rem}.feedback-form-card,.feedback-list-card{padding:18px}.section-title{font-size:1.1rem}.feedback-item-header{flex-direction:column;align-items:flex-start;gap:8px}.btn-submit{padding:12px 18px}}@media(max-width:480px){.feedback-page{padding:12px}.feedback-header h1{font-size:1.4rem}.feedback-form-card,.feedback-list-card{padding:16px}.message-box{font-size:.85rem;padding:12px 14px}.form-select,.form-input,.form-textarea{font-size:.9rem;padding:10px 12px}}.feedback-replies{margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.feedback-replies-loading{text-align:center;font-size:.85rem;color:var(--text-sub);padding:8px 0}.feedback-reply{font-size:.85rem;border-radius:10px;padding:8px 10px;max-width:85%}.feedback-reply-user{align-self:flex-end;background:#10b9811f;border:1px solid rgba(16,185,129,.2)}.feedback-reply-admin{align-self:flex-start;background:#3b82f61f;border:1px solid rgba(59,130,246,.2)}.feedback-reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.feedback-reply-author{font-weight:600;font-size:.8rem}.feedback-reply-time{font-size:.72rem;color:var(--text-sub)}.feedback-reply-content{white-space:pre-wrap;word-break:break-word;line-height:1.5;color:var(--text-main)}.feedback-reply-form{margin-top:10px;display:flex;gap:8px;align-items:flex-end}.feedback-reply-textarea{flex:1;min-height:40px;resize:vertical;font-size:.85rem;padding:8px 10px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-main);font-family:inherit;transition:border-color .2s}.feedback-reply-textarea:focus{outline:none;border-color:var(--primary)}.feedback-reply-textarea::placeholder{color:var(--text-sub);opacity:.7}.feedback-reply-send{align-self:flex-end;padding:8px 14px;font-size:.85rem;font-weight:600;border-radius:999px;border:none;cursor:pointer;background:var(--primary);color:#fff;transition:all .2s}.feedback-reply-send:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.feedback-reply-send:disabled{opacity:.6;cursor:not-allowed;transform:none}.reset-password-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%)}.reset-password-container{width:100%;max-width:480px}.reset-password-card{background:var(--card-bg);border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.reset-password-title{font-size:2rem;font-weight:800;color:var(--text-main);margin:0 0 8px;text-align:center}.reset-password-subtitle{font-size:.95rem;color:var(--text-sub);margin:0 0 30px;text-align:center}.reset-password-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:.9rem;font-weight:600;color:var(--text-main)}.form-input{width:100%;padding:14px 16px;border:2px solid var(--border-color);border-radius:12px;font-size:1rem;background:var(--bg-secondary);color:var(--text-main);transition:border-color .2s,background .2s;outline:none}.form-input:focus{border-color:var(--primary);background:var(--bg)}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input::placeholder{color:var(--text-sub);opacity:.7}.btn-reset-password,.btn-cancel{width:100%;padding:14px 20px;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;border:none}.btn-reset-password{background:var(--primary);color:#fff;box-shadow:0 4px 12px #4f46e54d}.btn-reset-password:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}.btn-reset-password:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-cancel{background:var(--bg-secondary);color:var(--text-main);border:2px solid var(--border-color)}.btn-cancel:hover:not(:disabled){background:var(--bg-tertiary)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.error-message{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ef44441a;border:1px solid var(--danger);border-radius:10px;color:var(--danger);font-size:.9rem;animation:shake .4s ease-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.error-icon{font-size:1.2rem;flex-shrink:0}.success-message{text-align:center;padding:40px 20px}.success-icon{font-size:4rem;margin-bottom:20px;animation:bounceIn .6s ease-out}@keyframes bounceIn{0%{opacity:0;transform:scale(.3)}50%{opacity:1;transform:scale(1.1)}to{transform:scale(1)}}.success-message h3{font-size:1.5rem;font-weight:700;color:var(--success);margin:0 0 12px}.success-message p{font-size:.95rem;color:var(--text-sub);margin:0}.reset-invalid{text-align:center;padding:40px 20px}.invalid-icon{font-size:4rem;margin-bottom:20px}.reset-invalid h2{font-size:1.5rem;font-weight:700;color:var(--text-main);margin:0 0 12px}.reset-invalid p{font-size:.95rem;color:var(--text-sub);margin:0 0 30px;line-height:1.6}.btn-back-to-login{padding:14px 32px;background:var(--primary);color:#fff;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #4f46e54d}.btn-back-to-login:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 16px #4f46e566}.reset-loading{text-align:center;padding:60px 20px;color:var(--text-sub)}.loading-spinner{font-size:3rem;margin-bottom:20px;display:inline-block;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reset-loading p{font-size:1rem;margin:0}@media(max-width:768px){.reset-password-card{padding:30px}.reset-password-title{font-size:1.6rem}.reset-password-subtitle{font-size:.9rem}}@media(max-width:480px){.reset-password-page{padding:15px}.reset-password-card{padding:24px;border-radius:16px}.reset-password-title{font-size:1.4rem}.form-input{padding:12px 14px;font-size:.95rem}.btn-reset-password,.btn-cancel{padding:12px 18px;font-size:.95rem}.success-icon,.invalid-icon{font-size:3rem}.loading-spinner{font-size:2.5rem}}.admin-feedback-page{max-width:960px;margin:0 auto;padding:24px 16px}.admin-feedback-header h1{font-size:1.8rem;font-weight:700;color:var(--text-main);margin:0 0 4px}.admin-feedback-header p{font-size:.9rem;color:var(--text-sub);margin:0 0 20px}.admin-feedback-error{margin-top:12px;margin-bottom:12px;padding:10px 12px;border-radius:8px;background:#ef44441a;color:var(--danger);cursor:pointer;font-size:.9rem}.admin-feedback-filters{display:flex;gap:8px;margin:16px 0}.admin-feedback-filters button{border:none;padding:6px 12px;border-radius:999px;font-size:.85rem;cursor:pointer;background:var(--bg-secondary);color:var(--text-sub);transition:all .2s}.admin-feedback-filters button:hover{background:var(--bg-tertiary)}.admin-feedback-filters button.active{background:var(--primary);color:#fff}.admin-feedback-loading,.admin-feedback-empty{text-align:center;padding:40px 20px;color:var(--text-sub);font-size:.95rem}.admin-feedback-list{display:flex;flex-direction:column;gap:12px}.admin-feedback-item{padding:14px 16px;border-radius:12px;background:var(--card-bg);border:1px solid var(--border-color);transition:all .2s}.admin-feedback-item:hover{border-color:var(--primary);box-shadow:0 2px 8px #4f46e51a}.admin-feedback-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.meta-line{display:flex;gap:4px;font-size:.85rem;color:var(--text-sub);margin-bottom:4px}.meta-label{font-weight:600}.meta-value{color:var(--text-main)}.meta-id{margin-left:4px;font-size:.8rem;color:var(--text-sub)}.content-block{margin:8px 0;font-size:.95rem;color:var(--text-main);white-space:pre-wrap;word-break:break-word;line-height:1.6}.contact-block{font-size:.85rem;color:var(--text-sub);margin-bottom:6px;padding:6px 10px;background:var(--bg-secondary);border-radius:6px}.status-tag{font-size:.75rem;padding:3px 10px;border-radius:999px;font-weight:600}.status-open{background:#f59e0b26;color:var(--warning)}.status-reviewed{background:#3b82f626;color:#3b82f6}.status-closed{background:#6b728026;color:var(--text-sub)}.admin-feedback-item-footer{display:flex;justify-content:space-between;align-items:center;margin-top:10px}.admin-feedback-item-footer .time{font-size:.8rem;color:var(--text-sub)}.admin-feedback-item-footer .actions{display:flex;gap:8px}.admin-feedback-item-footer button{border:none;border-radius:999px;padding:5px 12px;font-size:.8rem;font-weight:600;cursor:pointer;background:var(--bg-secondary);color:var(--primary);transition:all .2s}.admin-feedback-item-footer button:hover:not(:disabled){background:var(--primary);color:#fff}.admin-feedback-item-footer button.danger{color:var(--danger)}.admin-feedback-item-footer button.danger:hover:not(:disabled){background:var(--danger);color:#fff}.admin-feedback-item-footer button:disabled{opacity:.6;cursor:not-allowed}@media(max-width:768px){.admin-feedback-page{padding:16px 12px}.admin-feedback-header h1{font-size:1.5rem}.admin-feedback-item-header{flex-direction:column;align-items:flex-start;gap:6px}.admin-feedback-item-footer{flex-direction:column;align-items:flex-start;gap:10px}.admin-feedback-item-footer .actions{width:100%}.admin-feedback-item-footer button{flex:1}}.admin-feedback-replies{margin-top:12px;padding-top:10px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:8px}.admin-feedback-replies-loading{text-align:center;font-size:.85rem;color:var(--text-sub);padding:8px 0}.admin-feedback-reply{font-size:.85rem;border-radius:10px;padding:8px 10px;max-width:85%}.admin-feedback-reply-user{align-self:flex-end;background:#10b9811f;border:1px solid rgba(16,185,129,.2)}.admin-feedback-reply-admin{align-self:flex-start;background:#3b82f61f;border:1px solid rgba(59,130,246,.2)}.admin-feedback-reply-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.admin-feedback-reply-author{font-weight:600;font-size:.8rem}.admin-feedback-reply-time{font-size:.72rem;color:var(--text-sub)}.admin-feedback-reply-content{white-space:pre-wrap;word-break:break-word;line-height:1.5;color:var(--text-main)}.admin-feedback-reply-form{margin-top:10px;display:flex;gap:8px;align-items:flex-end}.admin-feedback-reply-textarea{flex:1;min-height:40px;resize:vertical;font-size:.85rem;padding:8px 10px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-main);font-family:inherit;transition:border-color .2s}.admin-feedback-reply-textarea:focus{outline:none;border-color:var(--primary)}.admin-feedback-reply-textarea::placeholder{color:var(--text-sub);opacity:.7}.admin-feedback-reply-send{align-self:flex-end;padding:8px 14px;font-size:.85rem;font-weight:600;border-radius:999px;border:none;cursor:pointer;background:var(--primary);color:#fff;transition:all .2s}.admin-feedback-reply-send:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.admin-feedback-reply-send:disabled{opacity:.6;cursor:not-allowed;transform:none}.guide-page{max-width:960px;margin:0 auto;padding:24px 16px 40px}.guide-header{position:relative;margin-bottom:24px;padding-top:2.5rem}.guide-back-button{position:absolute;left:0;top:0;padding:.5rem 1rem;border-radius:999px;border:1px solid var(--border-color);background:var(--card-bg);color:var(--text-main);font-size:.85rem;font-weight:500;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem;transition:background .2s,transform .1s,box-shadow .2s}.guide-back-button:hover{background:var(--bg-tertiary);transform:translateY(-1px);box-shadow:0 2px 6px #00000026}.guide-back-button:active{transform:translateY(0);box-shadow:none}.guide-header h1{font-size:2rem;font-weight:800;color:var(--text-main);margin-bottom:8px}.guide-subtitle{font-size:.95rem;color:var(--text-sub);margin:0}.guide-section{margin-top:24px}.guide-section h2{font-size:1.3rem;font-weight:700;margin-bottom:10px;color:var(--text-main)}.guide-card-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}.guide-card{background:var(--card-bg);border-radius:12px;border:1px solid var(--border-color);padding:12px 14px;box-shadow:0 4px 12px #0f172a0d;font-size:.9rem;color:var(--text-sub)}.guide-card h3{margin:0 0 6px;font-size:1rem;color:var(--text-main)}.guide-list{margin:0;padding-left:18px;font-size:.9rem;color:var(--text-sub);line-height:1.7}.guide-list li{margin-bottom:8px}.guide-list kbd{padding:2px 6px;border-radius:4px;background:var(--bg-tertiary);border:1px solid var(--border-color);font-size:.8rem;font-family:monospace;color:var(--text-main)}@media(max-width:768px){.guide-page{padding:16px 12px 32px}.guide-header{padding-top:3rem}.guide-back-button{font-size:.8rem;padding:.4rem .75rem}.guide-header h1{font-size:1.5rem}.guide-card-list{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--card-bg);border-radius:20px;box-shadow:var(--card-shadow);border:1px solid var(--border-color);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--border-color)}.modal-header h3{margin:0;font-size:1.5rem;font-weight:800;color:var(--text-main);display:flex;align-items:center;gap:10px}.btn-close{width:36px;height:36px;border:none;background:var(--bg-tertiary);color:var(--text-sub);border-radius:10px;font-size:1.3rem;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn-close:hover{background:var(--bg-secondary);color:var(--text-main);transform:rotate(90deg)}.dict-info-banner{background:linear-gradient(135deg,#818cf82e,#94a3b80f);padding:20px 28px;border-bottom:1px solid var(--border-color)}.dict-info-banner h4{margin:0 0 6px;font-size:1.2rem;font-weight:700;color:var(--primary)}.dict-info-banner p{margin:0;font-size:.9rem;color:var(--text-sub)}.modal-body{padding:28px;display:flex;flex-direction:column;gap:28px}.config-section{display:flex;flex-direction:column;gap:12px}.config-label{font-size:.95rem;font-weight:700;color:var(--text-main);margin-bottom:4px}.quantity-presets{display:flex;gap:8px;flex-wrap:wrap}.preset-btn{padding:10px 18px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;font-size:.9rem;font-weight:600;color:var(--text-main);cursor:pointer;transition:all .2s}.preset-btn:hover{border-color:var(--primary);background:var(--bg-tertiary)}.preset-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 4px 12px #4f46e54d}.quantity-slider{width:100%;height:6px;border-radius:3px;background:var(--border-color);outline:none;cursor:pointer;-webkit-appearance:none}.quantity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;box-shadow:0 2px 6px #4f46e566;transition:all .2s}.quantity-slider::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 4px 12px #4f46e580}.quantity-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary);cursor:pointer;border:none;box-shadow:0 2px 6px #4f46e566;transition:all .2s}.quantity-slider::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 4px 12px #4f46e580}.quantity-display{text-align:center;font-size:1.1rem;font-weight:700;color:var(--primary);padding:8px;background:#818cf81f;border-radius:10px}.difficulty-filters{display:flex;gap:8px;flex-wrap:wrap}.difficulty-btn{padding:10px 16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:10px;font-size:1rem;color:#fbbf24;cursor:pointer;transition:all .2s;min-width:60px;text-align:center}.difficulty-btn:hover{border-color:#fbbf24;background:var(--bg-tertiary)}.difficulty-btn.active{background:#fbbf24;border-color:#fbbf24;color:#fff;box-shadow:0 4px 12px #fbbf244d}.difficulty-hint{font-size:.85rem;color:var(--text-sub);padding:8px 12px;background:var(--bg-tertiary);border-radius:8px}.mode-selector{display:flex;gap:12px}.mode-btn{flex:1;padding:16px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:12px;cursor:pointer;transition:all .2s;text-align:left;display:flex;flex-direction:column;gap:6px;font-size:1rem;font-weight:600;color:var(--text-main)}.mode-btn:hover{border-color:var(--primary);background:var(--bg-tertiary)}.mode-btn.active{border-color:var(--primary);background:#818cf829;box-shadow:0 4px 12px #4f46e533}.mode-desc{font-size:.8rem;font-weight:500;color:var(--text-sub)}.import-progress{padding:20px 28px;background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--success));transition:width .3s ease-out;border-radius:4px}.progress-text{text-align:center;font-size:.9rem;font-weight:600;color:var(--text-main)}.modal-footer{display:flex;gap:12px;padding:20px 28px;border-top:1px solid var(--border-color);background:var(--bg-tertiary);border-radius:0 0 20px 20px}.btn{flex:1;padding:14px 24px;border:none;border-radius:12px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-cancel{background:var(--bg-secondary);color:var(--text-sub);border:2px solid var(--border-color)}.btn-cancel:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-color)}.btn-primary{background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%);color:#fff;box-shadow:0 4px 12px #4f46e54d}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5b21b6 0%,var(--primary) 100%);box-shadow:0 6px 16px #4f46e566;transform:translateY(-2px)}.btn-primary:active:not(:disabled){transform:translateY(0)}@media(max-width:768px){.modal-content{max-height:95vh;border-radius:20px 20px 0 0}.modal-header,.modal-body,.modal-footer{padding:20px}.dict-info-banner{padding:16px 20px}.mode-selector,.modal-footer{flex-direction:column}.btn{width:100%}}.modal-content::-webkit-scrollbar{width:8px}.modal-content::-webkit-scrollbar-track{background:var(--bg-tertiary)}.modal-content::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:4px}.modal-content::-webkit-scrollbar-thumb:hover{background:var(--text-sub)}.smart-import{max-width:800px;margin:0 auto;padding:24px}.smart-import-header{text-align:center;margin-bottom:32px}.smart-import-header h2{font-size:1.75rem;font-weight:800;color:var(--text-main);margin:0 0 8px}.smart-import-header p{font-size:1rem;color:var(--text-sub);margin:0}.input-stage{display:flex;flex-direction:column;gap:20px}.input-section{display:flex;flex-direction:column;gap:8px}.input-label{font-size:1rem;font-weight:600;color:var(--text-main);display:flex;flex-direction:column;gap:4px}.input-hint{font-size:.85rem;font-weight:400;color:var(--text-sub)}.word-input{width:100%;padding:16px;border:2px solid var(--border-color);border-radius:12px;font-size:1rem;font-family:Consolas,Monaco,monospace;line-height:1.6;resize:vertical;background:var(--card-bg);color:var(--text-main);transition:border-color .2s}.word-input:focus{outline:none;border-color:var(--primary)}.word-input::placeholder{color:var(--text-sub);opacity:.6}.input-stats{display:flex;justify-content:flex-end;padding:8px 0}.stat-item{font-size:.9rem;color:var(--text-sub)}.stat-item strong{color:var(--primary);font-weight:700}.action-buttons{display:flex;justify-content:center;gap:16px;margin-top:16px}.btn-large{padding:14px 32px!important;font-size:1.05rem!important}.preview-stage{display:flex;flex-direction:column;gap:24px}.summary-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.summary-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:16px;padding:20px;text-align:center;transition:transform .2s}.summary-card:hover{transform:translateY(-2px)}.summary-value{font-size:2.5rem;font-weight:800;line-height:1;margin-bottom:8px}.summary-label{font-size:.9rem;color:var(--text-sub)}.summary-card.total .summary-value{color:var(--primary)}.summary-card.found .summary-value{color:var(--success)}.summary-card.not-found .summary-value{color:var(--warning)}.match-progress{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px}.match-progress .progress-bar{height:12px;background:var(--bg-tertiary);border-radius:6px;overflow:hidden;margin-bottom:8px}.match-progress .progress-fill{height:100%;background:linear-gradient(90deg,var(--success),#34d399);border-radius:6px;transition:width .5s ease-out}.match-progress .progress-text{font-size:.9rem;color:var(--text-sub);text-align:center}.preview-list{background:var(--card-bg);border:1px solid var(--border-color);border-radius:16px;overflow:hidden}.preview-list h3{font-size:1.1rem;font-weight:700;color:var(--text-main);margin:0;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-tertiary)}.preview-items{max-height:400px;overflow-y:auto}.preview-item{display:flex;align-items:flex-start;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border-color);transition:background .2s}.preview-item:last-child{border-bottom:none}.preview-item:hover{background:var(--bg-tertiary)}.preview-item.found{background:#10b9810d}.preview-item.not-found{background:#f59e0b0d}.item-status{font-size:1.2rem;flex-shrink:0;width:28px;text-align:center}.item-content{flex:1;min-width:0}.item-word{font-size:1.1rem;font-weight:700;color:var(--text-main);margin-bottom:4px}.item-meaning{font-size:.9rem;color:var(--text-sub);line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-source{font-size:.8rem;color:var(--primary);margin-top:4px}.item-warning{font-size:.85rem;color:var(--warning);font-style:italic}.not-found-option{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:12px;padding:16px 20px}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:.95rem;color:var(--text-main)}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}.smart-import .btn{padding:12px 24px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px}.smart-import .btn-primary{background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%);color:#fff}.smart-import .btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#5b21b6 0%,var(--primary) 100%);box-shadow:0 4px 12px #4f46e566;transform:translateY(-1px)}.smart-import .btn-primary:disabled{background:var(--text-sub);cursor:not-allowed;opacity:.6}.smart-import .btn-secondary{background:var(--bg-tertiary);color:var(--text-main);border:2px solid var(--border-color)}.smart-import .btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--primary)}.preview-items::-webkit-scrollbar{width:6px}.preview-items::-webkit-scrollbar-track{background:transparent}.preview-items::-webkit-scrollbar-thumb{background:var(--text-sub);border-radius:3px;opacity:.5}.preview-items::-webkit-scrollbar-thumb:hover{background:var(--text-main)}@media(max-width:640px){.smart-import{padding:16px}.smart-import-header h2{font-size:1.5rem}.summary-cards{grid-template-columns:1fr;gap:12px}.summary-card{padding:16px;display:flex;align-items:center;justify-content:space-between}.summary-value{font-size:1.8rem;margin-bottom:0}.action-buttons{flex-direction:column}.btn-large{width:100%;justify-content:center}}.advanced-import{max-width:1200px;margin:0 auto;padding:32px 24px}.import-header{margin-bottom:32px;text-align:center}.import-header h2{font-size:2rem;font-weight:800;color:var(--text-main);margin:0 0 8px;display:flex;align-items:center;justify-content:center;gap:12px}.import-header p{font-size:1rem;color:var(--text-sub);margin:0}.import-mode-switcher{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px;max-width:700px;margin-left:auto;margin-right:auto}.mode-tab{display:flex;flex-direction:column;align-items:center;gap:8px;padding:20px 24px;background:var(--card-bg);border:2px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .3s;text-align:center}.mode-tab:hover{border-color:var(--primary);background:var(--bg-tertiary)}.mode-tab.active{border-color:var(--primary);background:#4f46e51a;box-shadow:0 4px 12px #4f46e526}.mode-icon{font-size:2rem}.mode-text{font-size:1.1rem;font-weight:700;color:var(--text-main)}.mode-desc{font-size:.85rem;color:var(--text-sub)}.mode-tab.active .mode-text{color:var(--primary)}.dict-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px;margin-top:24px}.dict-card{background:var(--card-bg);border:2px solid var(--border-color);border-radius:16px;padding:24px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.dict-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary),var(--success));transform:scaleX(0);transform-origin:left;transition:transform .3s}.dict-card:hover{border-color:var(--primary);box-shadow:0 8px 24px #4f46e526;transform:translateY(-4px)}.dict-card:hover:before{transform:scaleX(1)}.dict-card:active{transform:translateY(-2px)}.dict-icon{width:64px;height:64px;border-radius:16px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;font-size:2.5rem;flex-shrink:0;box-shadow:0 4px 12px #0000000d}.dict-info{flex:1;display:flex;flex-direction:column;gap:8px}.dict-name{font-size:1.25rem;font-weight:700;color:var(--text-main);margin:0;line-height:1.3}.dict-desc{font-size:.9rem;color:var(--text-sub);margin:0;line-height:1.5}.dict-meta{display:flex;align-items:center;gap:12px;margin-top:4px}.dict-count{font-size:.85rem;font-weight:600;color:var(--primary);padding:4px 10px;background:var(--bg-tertiary);border-radius:8px}.dict-category{font-size:.85rem;font-weight:600;color:var(--text-sub);padding:4px 10px;background:var(--bg-tertiary);border-radius:8px}.btn-import-quick{width:100%;padding:12px 20px;background:linear-gradient(135deg,var(--primary) 0%,#6366f1 100%);color:#fff;border:none;border-radius:12px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px}.btn-import-quick:hover{background:linear-gradient(135deg,#5b21b6 0%,var(--primary) 100%);box-shadow:0 4px 12px #4f46e566;transform:translateY(-1px)}.btn-import-quick:active{transform:translateY(0)}@media(max-width:768px){.advanced-import{padding:24px 16px}.import-header h2{font-size:1.5rem}.import-mode-switcher{grid-template-columns:1fr;gap:12px;margin-bottom:24px}.mode-tab{flex-direction:row;justify-content:flex-start;padding:16px 20px;gap:12px}.mode-icon{font-size:1.5rem}.mode-text{font-size:1rem}.mode-desc{display:none}.dict-grid{grid-template-columns:1fr;gap:16px}.dict-card{padding:20px}.dict-icon{width:56px;height:56px;font-size:2rem}}.dict-grid:empty:after{content:"暂无可用词典";display:block;text-align:center;padding:48px;color:var(--text-sub);font-size:1rem;grid-column:1 / -1}*{box-sizing:border-box;margin:0;padding:0}body{margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}.app{min-height:100vh;background:var(--bg);display:flex;position:relative}.sidebar-wrapper{position:relative}.sidebar-wrapper.desktop-collapsed{display:none}.main-content{flex:1;min-height:100vh;padding:20px;transition:margin-left .3s;background:var(--bg);overflow-x:hidden}@media(max-width:767px){.main-content{padding:15px}}.main-content.with-sidebar{margin-left:0;margin-right:0}.main-content.with-sidebar.sidebar-left{margin-left:var(--sidebar-width, 280px)}.main-content.with-sidebar.sidebar-right{margin-right:var(--sidebar-width, 280px)}.sidebar-collapsed-handle{position:fixed;top:50%;transform:translateY(-50%);z-index:150;width:32px;height:80px;background:var(--card-bg);border:1px solid var(--border-color);box-shadow:0 4px 10px #00000026;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-main);font-size:1.2rem;transition:all .2s}.sidebar-collapsed-handle:hover{background:var(--primary);color:#fff;border-color:var(--primary)}.sidebar-collapsed-left{left:0;border-radius:0 8px 8px 0;border-left:none}.sidebar-collapsed-right{right:0;border-radius:8px 0 0 8px;border-right:none}.mobile-menu-btn{display:none;position:fixed;top:50%;left:0;transform:translateY(-50%);z-index:101;width:36px;height:72px;border-radius:0 12px 12px 0;background:var(--card-bg);border:2px solid var(--border-color);border-left:none;font-size:1.3rem;cursor:pointer;box-shadow:2px 0 8px #0000001a;transition:all .2s;color:var(--text-main)}.mobile-menu-btn:hover{background:var(--bg-tertiary);width:42px}.mobile-menu-btn:active{background:var(--primary);color:#fff}.sidebar-overlay{display:none}.stats-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center;padding:2rem}.stats-placeholder h2{font-size:2rem;color:var(--text-main);margin-bottom:1rem}.stats-placeholder p{font-size:1.1rem;color:var(--text-sub)}@media(max-width:1024px){.main-content.with-sidebar,.main-content.with-sidebar.sidebar-left,.main-content.with-sidebar.sidebar-right{margin-left:0;margin-right:0}.sidebar-wrapper.desktop-collapsed{display:block}.sidebar-wrapper{position:fixed;top:0;bottom:0;height:100vh;z-index:200;transition:transform .3s cubic-bezier(.4,0,.2,1);width:var(--sidebar-width, 280px)}.sidebar-wrapper.sidebar-left{left:0;transform:translate(-100%)}.sidebar-wrapper.sidebar-right{right:0;transform:translate(100%)}.sidebar-wrapper.mobile-open.sidebar-left,.sidebar-wrapper.mobile-open.sidebar-right{transform:translate(0);box-shadow:0 0 50px #0003}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:190;opacity:0;pointer-events:none;transition:opacity .3s;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.sidebar-overlay.show{opacity:1;pointer-events:all}.mobile-menu-btn{display:flex;align-items:center;justify-content:center}.sidebar-collapsed-handle{display:none}}@media(max-width:768px){.mobile-menu-btn{width:32px;height:64px;font-size:1.2rem}.stats-placeholder h2{font-size:1.5rem}.stats-placeholder p{font-size:1rem}}
