:root{--color-primary: #4f46e5;--color-primary-hover: #4338ca;--color-primary-light: #eef2ff;--color-primary-100: #e0e7ff;--color-primary-200: #c7d2fe;--color-primary-rgb: 79, 70, 229;--color-success: #16a34a;--color-success-hover: #15803d;--color-success-light: #f0fdf4;--color-success-border: #22c55e;--color-danger: #dc2626;--color-danger-hover: #b91c1c;--color-danger-light: #fef2f2;--color-danger-border: #fecaca;--color-warning-text: #b45309;--color-warning-bg: #fef3c7;--color-warning-border: #fde68a;--color-text: #1e293b;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-faint: #cbd5e1;--color-bg: #f1f5f9;--color-bg-alt: #e8edf4;--color-surface: #ffffff;--color-surface-hover: #f8fafc;--color-border: #e2e8f0;--color-border-light: #f1f5f9;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 2px 6px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .04);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .1), 0 2px 4px rgba(0, 0, 0, .05);--shadow-xl: 0 10px 30px rgba(0, 0, 0, .12), 0 4px 8px rgba(0, 0, 0, .06);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-full: 9999px;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;color:var(--color-text);background-color:var(--color-bg);-webkit-font-smoothing:antialiased}[data-theme=dark]{--color-primary: #818cf8;--color-primary-hover: #6366f1;--color-primary-light: #1e1b4b;--color-primary-100: #312e81;--color-primary-200: #3730a3;--color-primary-rgb: 129, 140, 248;--color-success: #4ade80;--color-success-hover: #22c55e;--color-success-light: #052e16;--color-success-border: #166534;--color-danger: #f87171;--color-danger-hover: #ef4444;--color-danger-light: #450a0a;--color-danger-border: #991b1b;--color-warning-text: #fbbf24;--color-warning-bg: #451a03;--color-warning-border: #78350f;--color-text: #e2e8f0;--color-text-secondary: #cbd5e1;--color-text-muted: #94a3b8;--color-text-faint: #475569;--color-bg: #0f172a;--color-bg-alt: #1e293b;--color-surface: #1e293b;--color-surface-hover: #334155;--color-border: #334155;--color-border-light: #1e293b;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 6px rgba(0, 0, 0, .4), 0 1px 2px rgba(0, 0, 0, .2);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .5), 0 2px 4px rgba(0, 0, 0, .3);--shadow-xl: 0 10px 30px rgba(0, 0, 0, .6), 0 4px 8px rgba(0, 0, 0, .4);color-scheme:dark}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{letter-spacing:-.02em;font-weight:700}h1{font-size:1.75rem;line-height:1.2}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}input:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.skip-link{position:absolute;left:-9999px;top:auto;z-index:10000;padding:.5rem 1rem;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:4px;font-weight:600}.skip-link:focus{left:8px;top:8px}*{scrollbar-width:thin;scrollbar-color:var(--color-text-faint) transparent}*::-webkit-scrollbar{width:6px;height:6px}*::-webkit-scrollbar-track{background:transparent}*::-webkit-scrollbar-thumb{background:var(--color-text-faint);border-radius:3px}*::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@keyframes fade-in-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}body{transition:background-color .3s ease,color .3s ease}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.container{max-width:900px;margin:0 auto;padding:2rem 1rem}.navbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;padding:0 1.5rem;height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);color:var(--color-text);box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100;transition:background .3s ease,box-shadow .3s ease,border-color .3s ease}.navbar a{color:var(--color-text);text-decoration:none;font-weight:500}.navbar a:hover{text-decoration:none}.navbar-brand a{display:flex;align-items:center;gap:.4rem;font-size:1.15rem;font-weight:800;letter-spacing:-.03em;padding:.35rem .75rem;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);transition:background .2s}.navbar-brand-icon{width:24px;height:24px;border-radius:50%}.navbar-brand a:hover{background:var(--color-primary-hover)}.navbar-toggle{display:none;background:none;border:none;cursor:pointer;padding:.5rem}.hamburger,.hamburger:before,.hamburger:after{display:block;width:22px;height:2px;background:var(--color-text);border-radius:2px;transition:transform .3s,opacity .3s;position:relative}.hamburger:before,.hamburger:after{content:"";position:absolute;left:0}.hamburger:before{top:-7px}.hamburger:after{top:7px}.hamburger.open{background:transparent}.hamburger.open:before{top:0;transform:rotate(45deg)}.hamburger.open:after{top:0;transform:rotate(-45deg)}.navbar-menu{display:flex;align-items:center;gap:.5rem}.navbar-links{display:flex;gap:.25rem;background:var(--color-bg);border-radius:var(--radius-full);padding:.2rem}.navbar-links a{padding:.4rem .85rem;border-radius:var(--radius-full);font-size:.85rem;font-weight:500;color:var(--color-text-secondary);transition:all .2s cubic-bezier(.22,1,.36,1)}.navbar-links a:hover{color:var(--color-text);background:var(--color-surface-hover)}.navbar-links a.active{color:var(--color-primary);background:rgba(var(--color-primary-rgb),.1);font-weight:600}.navbar-actions{display:flex;align-items:center;gap:.4rem;margin-left:.75rem}.navbar-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-full);background:var(--color-bg);color:var(--color-text-secondary);font-size:.85rem;font-family:inherit;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.22,1,.36,1)}.navbar-icon-btn:hover{background:var(--color-bg-alt);color:var(--color-text);transform:scale(1.05)}.navbar-icon-btn:active{transform:scale(.95)}.navbar-divider{width:1px;height:20px;background:var(--color-border);margin:0 .25rem}.navbar-email{font-size:.8rem;color:var(--color-text-muted);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-logout{padding:.35rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-full);background:transparent;color:var(--color-text-secondary);font-size:.8rem;font-family:inherit;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.22,1,.36,1)}.navbar-logout:hover{background:var(--color-bg);border-color:var(--color-border);color:var(--color-text)}.btn{display:inline-block;padding:.55rem 1.15rem;border:none;border-radius:var(--radius-full);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.22,1,.36,1);letter-spacing:.01em}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.btn:active{transform:translateY(0) scale(.97);box-shadow:none;transition-duration:.1s}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,#6366f1 100%);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,var(--color-primary-hover) 0%,var(--color-primary) 100%)}.btn-secondary{background:var(--color-surface);color:var(--color-text-secondary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-surface-hover);border-color:var(--color-text-muted)}.btn-danger{background:var(--color-danger);color:#fff}.btn-small{padding:.3rem .75rem;font-size:.8rem}.ai-icon{display:inline-block;vertical-align:-.15em;margin-right:.25em;opacity:.85}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.3rem;font-weight:600;font-size:.9rem;color:var(--color-text)}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color .2s ease,box-shadow .2s ease}.form-group select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2394a3b8' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;padding-right:2rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.form-actions{display:flex;gap:.5rem}.error{color:var(--color-danger);margin-bottom:.75rem;font-size:.9rem}.auth-page{max-width:400px;margin:4rem auto}.auth-page h1{margin-bottom:1.5rem;font-size:1.8rem}.auth-form{background:var(--color-surface);padding:1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin-bottom:1rem}.dashboard-page h1{margin-bottom:.25rem}.page-subtitle{color:var(--color-text-secondary);font-size:.95rem;margin-bottom:1.5rem}.import-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:1.5rem;text-align:center;margin-bottom:1.5rem;transition:border-color .2s,background .2s}.import-dropzone.dragging{border-color:var(--color-primary);background:var(--color-primary-light)}.import-dropzone p{margin:0 0 .5rem;color:var(--color-text-secondary)}.import-error{color:var(--color-danger);font-size:.9rem;margin-top:.5rem}.import-success{color:var(--color-success);font-size:.9rem;margin-top:.5rem}.homework-form{background:var(--color-surface);padding:1rem 1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin-bottom:1.5rem;border-top:3px solid var(--color-primary)}.form-row{display:flex;gap:.5rem;align-items:center}.homework-type-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.homework-type-option{padding:.5rem 1rem;border:none;background:var(--color-surface);color:var(--color-text-secondary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.homework-type-option+.homework-type-option{border-left:1px solid var(--color-border)}.homework-type-option:hover{background:var(--color-surface-hover);color:var(--color-text)}.homework-type-option.selected{background:var(--color-primary);color:#fff}.glossary-lang-pickers{display:flex;align-items:center;gap:.5rem}.glossary-lang-pickers .glossary-arrow{font-size:1.1rem;color:var(--color-text-secondary)}.form-row input{flex:1;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;background:var(--color-surface);color:var(--color-text);transition:border-color .2s ease,box-shadow .2s ease}.form-row input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.15)}.homework-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:2rem}.homework-card{display:flex;align-items:center;justify-content:space-between;background:var(--color-surface);padding:.85rem 1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md);border-left:4px solid var(--color-primary-200);transition:border-color .2s,box-shadow .25s cubic-bezier(.22,1,.36,1),transform .25s cubic-bezier(.22,1,.36,1),background .2s}.homework-card:hover{border-left-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px);background:var(--color-surface-hover)}.homework-info{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem 1rem}.homework-count{color:var(--color-text-secondary);font-size:.85rem}.homework-dates{width:100%;color:var(--color-text-muted);font-size:.8rem}.homework-actions{display:flex;gap:.5rem}.homework-card-actions{display:flex;align-items:center;gap:.5rem}.homework-menu-wrapper{position:relative;flex-shrink:0}.homework-menu-trigger{background:none;border:none;font-size:1.25rem;line-height:1;padding:.25rem .5rem;cursor:pointer;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:background .15s,color .15s}.homework-menu-trigger:hover{background:var(--color-surface-hover);color:var(--color-text)}.homework-menu-dropdown{position:absolute;right:0;top:100%;margin-top:.25rem;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);min-width:160px;z-index:100;overflow:hidden;border:1px solid var(--color-border)}.homework-card:has(.homework-menu-dropdown){z-index:50;position:relative}.homework-menu-item{display:block;width:100%;padding:.6rem 1rem;background:none;border:none;text-align:left;font-size:.9rem;font-family:inherit;color:var(--color-text);cursor:pointer;text-decoration:none;transition:background .1s}.homework-menu-item:hover{background:var(--color-surface-hover)}.homework-menu-item-danger{color:var(--color-danger)}.homework-menu-item-danger:hover{background:var(--color-danger-light)}.homework-questions{margin-top:2rem}.homework-questions h2{margin-bottom:1rem}.homework-selector{background:var(--color-surface);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:1rem;margin-top:1.5rem;border-top:4px solid var(--color-primary)}.homework-selector label{font-weight:600;color:var(--color-text)}.homework-selector select{padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;min-width:300px;background:var(--color-surface);color:var(--color-text)}.homework-selector select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.15)}.questions-page h1{margin-bottom:1.5rem}.back-link{display:inline-block;margin-bottom:1rem;color:var(--color-primary);text-decoration:none;font-weight:500}.back-link:hover{text-decoration:underline}.add-question-section{margin-bottom:1.5rem}.add-question-heading{font-size:1.1rem;font-weight:600;color:var(--color-primary);margin-bottom:.75rem}.question-form{background:var(--color-surface);padding:1rem 1.25rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md);margin-bottom:1.5rem;border-top:3px solid var(--color-primary)}.question-form .form-group{margin-bottom:.6rem}.question-list{display:flex;flex-direction:column;gap:1rem}.question-card{background:var(--color-surface);padding:1rem 1.5rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md);border-left:4px solid var(--color-primary-200);transition:border-color .2s,box-shadow .25s cubic-bezier(.22,1,.36,1),transform .25s cubic-bezier(.22,1,.36,1)}.question-card:hover{border-left-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.question-content p{margin-bottom:.3rem}.question-explanation{color:var(--color-text-secondary);font-style:italic}.question-actions{display:flex;gap:.5rem;margin-top:.75rem}.question-meta{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.5rem}.glossary-table{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-md);overflow:hidden}.glossary-eval-mode{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-bottom:1px solid var(--color-border)}.glossary-eval-label{font-size:.8rem;color:var(--color-text-muted)}.glossary-table-header{display:grid;grid-template-columns:1fr auto 1fr 1.2fr auto;gap:.5rem;padding:.6rem 1rem;background:var(--color-bg-alt);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border)}.glossary-table-row{display:grid;grid-template-columns:1fr auto 1fr 1.2fr auto;gap:.5rem;align-items:center;padding:.6rem 1rem;border-bottom:1px solid var(--color-border-light);transition:background .15s}.glossary-table-row:last-child{border-bottom:none}.glossary-table-row:not(.glossary-table-row-new):not(.glossary-table-row-editing):hover{background:var(--color-surface-hover)}.glossary-table-row-new{background:var(--color-primary-light);border-bottom:2px solid var(--color-primary-200)}.glossary-table-row-editing{background:var(--color-primary-light)}.glossary-table-row input[type=text]{width:100%;padding:.35rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-surface);color:var(--color-text)}.glossary-table-row input[type=text]:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.15)}.glossary-col-arrow{text-align:center;width:1.5rem;color:var(--color-text-muted);flex-shrink:0}.glossary-col-actions{display:flex;gap:.35rem;justify-content:flex-end;white-space:nowrap}.glossary-word{font-weight:600}.glossary-speak-btn{margin-left:.4rem;vertical-align:middle}.glossary-example-text{color:var(--color-text-muted);font-style:italic;font-size:.85rem}.glossary-row-error{grid-column:1 / -1;color:var(--color-danger);font-size:.8rem;margin:0}.glossary-empty{padding:2rem 1rem;text-align:center;color:var(--color-text-muted)}@media(max-width:700px){.glossary-table-header{display:none}.glossary-table-row{grid-template-columns:1fr auto 1fr;grid-template-rows:auto auto auto}.glossary-col-example{grid-column:1 / -1}.glossary-col-actions{grid-column:1 / -1;justify-content:flex-start;padding-top:.25rem}}.badge{display:inline-block;padding:.15rem .5rem;font-size:.75rem;border-radius:var(--radius-full);background:var(--color-primary-light);color:var(--color-primary);border:1px solid var(--color-primary-200)}.badge-concept{background:#e8f0fe;color:#1a56db;border-color:#bdd4fe}.badge-glossary{background:#e6f9f0;color:#0d7a4f;border-color:#a7f3d0}[data-theme=dark] .badge-concept{background:#1e2a4a;color:#93b4f8;border-color:#2d4a8a}[data-theme=dark] .badge-glossary{background:#0a2e1f;color:#6ee7b7;border-color:#166534}.form-row .form-group{flex:1}.segmented-control{display:inline-flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.segmented-btn{padding:.45rem 1.2rem;border:none;background:var(--color-surface);color:var(--color-text-secondary);font-size:.9rem;font-family:inherit;cursor:pointer;transition:background .15s,color .15s}.segmented-btn:not(:last-child){border-right:1px solid var(--color-border)}.segmented-btn:hover{background:var(--color-surface-hover)}.segmented-btn.active{background:var(--color-primary);color:#fff}.eval-mode-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.eval-mode-option{display:flex;flex-direction:column;align-items:center;gap:.15rem;padding:.4rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s;text-align:center}.eval-mode-option:hover{border-color:var(--color-primary-200);background:var(--color-surface-hover)}.eval-mode-option.active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 1px var(--color-primary)}.eval-mode-label{font-size:.85rem;font-weight:600;color:var(--color-text)}.eval-mode-option.active .eval-mode-label{color:var(--color-primary)}.eval-mode-desc{font-size:.7rem;color:var(--color-text-muted);line-height:1.2}.practice-page{text-align:center}.practice-page h1{margin-bottom:.25rem;text-align:left}.practice-page .page-subtitle{text-align:left}.practice-progress{color:var(--color-text-secondary);margin-bottom:1.5rem}.practice-card{background:var(--color-surface);padding:2.5rem 2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);margin-bottom:1.5rem;min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;border-top:4px solid var(--color-primary)}.practice-question h2{font-size:1.4rem;margin-bottom:.5rem}.practice-answer{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--color-border);width:100%}.practice-answer p{font-size:1.2rem;margin-bottom:.5rem}.practice-explanation{color:var(--color-text-secondary);font-size:.95rem;font-style:italic;margin-top:.5rem}.practice-controls{margin-bottom:1.5rem}.speech-rate{display:flex;align-items:center;gap:.5rem;color:var(--color-text-secondary);font-size:.9rem}.speech-rate input[type=range]{width:150px;accent-color:var(--color-primary)}.tts-no-voices-warning{text-align:center;font-size:.85rem;color:var(--color-warning-text);background:var(--color-warning-bg);border:1px solid var(--color-warning-border);border-radius:var(--radius-sm);padding:.5rem 1rem;margin-top:.75rem}.voice-selector{display:flex;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-secondary);font-size:.9rem;margin-top:.75rem}.voice-selector select{padding:.35rem .5rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.85rem;font-family:inherit;max-width:280px;background:var(--color-surface);color:var(--color-text)}.voice-selector select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.15)}.tts-mode-selector{display:flex;align-items:center;justify-content:center;gap:.75rem;color:var(--color-text-secondary);font-size:.9rem;margin-top:.75rem}.tts-mode-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.tts-mode-btn{padding:.3rem .85rem;font-size:.85rem;font-family:inherit;background:var(--color-surface);color:var(--color-text-secondary);border:none;cursor:pointer;transition:background .15s,color .15s}.tts-mode-btn:first-child{border-right:1px solid var(--color-border)}.tts-mode-btn.active{background:var(--color-primary);color:#fff}.tts-mode-btn:hover:not(.active){background:var(--color-surface-hover)}.practice-settings-row{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center;align-items:center;margin-bottom:1rem}.toggle-label{display:inline-flex;align-items:center;gap:.5rem;cursor:pointer;color:var(--color-text-secondary);font-size:.9rem}.toggle-label input{display:none}.toggle-slider{position:relative;width:40px;height:22px;background:var(--color-border);border-radius:11px;transition:background .2s}.toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform .2s;box-shadow:var(--shadow-sm)}.toggle-label input:checked+.toggle-slider{background:var(--color-primary)}.toggle-label input:checked+.toggle-slider:after{transform:translate(18px)}.test-page h1{margin-bottom:.5rem}.test-progress{color:var(--color-text-secondary);margin-bottom:1.5rem}.test-question{background:var(--color-surface);padding:2rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border-top:4px solid var(--color-primary)}.test-question h2{margin-bottom:1.5rem}.test-feedback{padding:1rem;border-radius:var(--radius-md);margin-top:1rem}.test-feedback.correct{background:var(--color-success-light);color:var(--color-success)}.test-feedback.incorrect{background:var(--color-danger-light);color:var(--color-danger)}.test-feedback p{margin-bottom:.5rem}.test-score{text-align:center;margin:2rem 0}.test-score h2{font-size:2rem}.test-actions{display:flex;justify-content:center;gap:.75rem;margin-bottom:2rem}.test-review{display:flex;flex-direction:column;gap:1rem}.results-page h1{margin-bottom:1.5rem}.results-summary{display:flex;gap:2rem;margin-bottom:2rem}.stat{background:var(--color-surface);padding:1.5rem 2rem;border-radius:var(--radius-md);box-shadow:var(--shadow-md);text-align:center;flex:1;border-bottom:3px solid var(--color-primary-200);transition:transform .25s cubic-bezier(.22,1,.36,1),box-shadow .25s cubic-bezier(.22,1,.36,1)}.stat:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-value{display:block;font-size:2.2rem;font-weight:800;background:linear-gradient(135deg,var(--color-primary),#6366f1);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{display:block;font-size:.85rem;color:var(--color-text-secondary);margin-top:.25rem}.results-list{display:flex;flex-direction:column;gap:.75rem}.result-card{padding:1rem 1.5rem;border-radius:var(--radius-md);border-left:4px solid}.result-card.correct{background:var(--color-success-light);border-color:var(--color-success-border)}.result-card.incorrect{background:var(--color-danger-light);border-color:var(--color-danger-border)}.result-card p{margin-bottom:.25rem}.result-card small{color:var(--color-text-secondary)}.ai-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.15rem .45rem;margin-left:.5rem;border-radius:var(--radius-sm);background:var(--color-primary-light);color:var(--color-primary);vertical-align:middle;letter-spacing:.02em}.session-card{border-radius:var(--radius-md);overflow:hidden;background:var(--color-surface);border:1px solid var(--color-border)}.session-header{display:flex;align-items:center;width:100%;padding:1rem 1.5rem;border:none;background:none;cursor:pointer;gap:1rem;font:inherit;color:inherit;text-align:left;transition:background .15s}.session-header:hover{background:var(--color-surface-hover)}.session-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.session-date{font-size:.85rem;color:var(--color-text-secondary)}.session-score{display:flex;gap:.5rem;align-items:baseline;font-weight:600}.session-percent{font-size:.85rem;color:var(--color-text-secondary);font-weight:400}.session-in-progress{font-size:.85rem;color:var(--color-text-secondary);font-style:italic}.session-chevron{font-size:.75rem;color:var(--color-text-secondary)}.session-detail{padding:0 1.5rem 1rem;display:flex;flex-direction:column;gap:.5rem}.dashboard-page,.questions-page,.practice-page,.test-page,.results-page,.privacy-page{animation:fade-in-up .4s ease-out both}.homework-list>.homework-card,.question-list>.question-card,.results-list>.session-card,.test-review>.result-card{animation:fade-in-up .35s ease-out both}.homework-list>:nth-child(1),.question-list>:nth-child(1),.results-list>:nth-child(1),.test-review>:nth-child(1){animation-delay:.03s}.homework-list>:nth-child(2),.question-list>:nth-child(2),.results-list>:nth-child(2),.test-review>:nth-child(2){animation-delay:.06s}.homework-list>:nth-child(3),.question-list>:nth-child(3),.results-list>:nth-child(3),.test-review>:nth-child(3){animation-delay:.09s}.homework-list>:nth-child(4),.question-list>:nth-child(4),.results-list>:nth-child(4),.test-review>:nth-child(4){animation-delay:.12s}.homework-list>:nth-child(5),.question-list>:nth-child(5),.results-list>:nth-child(5),.test-review>:nth-child(5){animation-delay:.15s}.homework-list>:nth-child(6),.question-list>:nth-child(6),.results-list>:nth-child(6),.test-review>:nth-child(6){animation-delay:.18s}.homework-list>:nth-child(7),.question-list>:nth-child(7),.results-list>:nth-child(7),.test-review>:nth-child(7){animation-delay:.21s}.homework-list>:nth-child(8),.question-list>:nth-child(8),.results-list>:nth-child(8),.test-review>:nth-child(8){animation-delay:.24s}.homework-list>:nth-child(9),.question-list>:nth-child(9),.results-list>:nth-child(9),.test-review>:nth-child(9){animation-delay:.27s}.homework-list>:nth-child(10),.question-list>:nth-child(10),.results-list>:nth-child(10),.test-review>:nth-child(10){animation-delay:.3s}.homework-list>:nth-child(n+11),.question-list>:nth-child(n+11),.results-list>:nth-child(n+11),.test-review>:nth-child(n+11){animation-delay:.3s}@media(max-width:768px){.navbar{height:auto;padding:.75rem 1rem}.navbar-toggle{display:block}.navbar-menu{display:none;flex-direction:column;width:100%;gap:.75rem;padding-top:.75rem}.navbar-menu.open{display:flex}.navbar-links{flex-direction:column;gap:.15rem;width:100%;background:none;padding:0;border-radius:0}.navbar-links a{padding:.5rem .75rem;border-radius:var(--radius-sm);font-size:.9rem;color:var(--color-text-secondary)}.navbar-links a.active{background:rgba(var(--color-primary-rgb),.1);color:var(--color-primary)}.navbar-actions{flex-wrap:wrap;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--color-border);width:100%;margin-left:0}.navbar-email{order:-1;width:100%;max-width:none}.navbar-divider{display:none}.container{padding:1.25rem .75rem}.homework-card{flex-direction:column;align-items:flex-start;gap:.75rem;padding:1rem}.homework-actions{flex-wrap:wrap;width:100%}.homework-selector{padding:1.25rem}.homework-selector select{min-width:0;width:100%}.practice-card{padding:1.25rem;min-height:150px}.practice-question h2{font-size:1.2rem}.practice-answer p{font-size:1.05rem}.practice-settings-row{flex-direction:column;gap:.75rem;align-items:center}.voice-selector{flex-direction:column;gap:.5rem}.voice-selector select{max-width:100%;width:200px}.results-summary{flex-direction:column;gap:.75rem}.test-question{padding:1.25rem}.auth-page{margin:2rem auto;padding:0 .5rem}.question-card{padding:1rem}.question-actions{flex-wrap:wrap}.eval-mode-grid{grid-template-columns:repeat(2,1fr)}.form-row{flex-direction:column;align-items:stretch}.form-row .btn{width:100%}}@media(max-width:480px){.container{padding:1rem .5rem}h1{font-size:1.4rem}.practice-question h2{font-size:1.1rem}.stat-value{font-size:1.5rem}.stat{padding:1rem}.test-score h2{font-size:1.5rem}.import-dropzone{padding:1rem}}.landing-page{margin:-2rem -1rem 0;background:var(--color-bg-alt);min-height:100vh;display:flex;flex-direction:column}.landing-container{flex:1;display:flex;align-items:center;justify-content:center;gap:clamp(3rem,6vw,8rem);width:100%;max-width:1200px;margin:0 auto;padding:2rem clamp(1.5rem,5vw,6rem) 4rem}.landing-left{flex:1 1 50%;max-width:580px}.landing-mascot{width:120px;height:120px;margin-bottom:1rem}.landing-brand{font-size:clamp(2.2rem,3.5vw,3.5rem);font-weight:800;color:var(--color-primary);margin:0 0 1rem;letter-spacing:-1px;line-height:1.1}.landing-tagline{font-size:clamp(1.05rem,1.4vw,1.4rem);color:var(--color-text);line-height:1.6;margin:0 0 1.75rem}.landing-features{display:flex;gap:.6rem;flex-wrap:wrap}.landing-feature{display:flex;align-items:center;gap:.4rem;background:var(--color-primary-100);color:var(--color-primary);border-radius:var(--radius-full);padding:.45rem 1rem;font-size:.9rem;font-weight:500}.landing-feature-icon{font-size:1rem}.landing-right{flex:0 1 420px;min-width:320px}.landing-card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);padding:1.5rem}.landing-form{display:flex;flex-direction:column;gap:.75rem}.landing-input{width:100%;padding:.875rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:1rem;font-family:inherit;color:var(--color-text);background:var(--color-surface);box-sizing:border-box;transition:border-color .2s ease,box-shadow .2s ease}.landing-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(var(--color-primary-rgb),.12)}.landing-input::placeholder{color:var(--color-text-muted)}.landing-error-slot{min-height:2.6rem}.landing-error{color:var(--color-danger);font-size:.9rem;margin:0;padding:.5rem .75rem;background:var(--color-danger-light);border-radius:var(--radius-sm);border:1px solid var(--color-danger-border);animation:fade-in .2s ease-out}.landing-btn-login{width:100%;padding:.75rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1.1rem;font-weight:700;cursor:pointer;transition:background .15s;margin-top:.25rem}.landing-btn-login:hover{background:var(--color-primary-hover)}.landing-btn-login:active,.landing-btn-create:active,.landing-btn-back:active{transform:scale(.97);transition-duration:.1s}.landing-btn-register{background:var(--color-success)}.landing-btn-register:hover{background:var(--color-success-hover)}.landing-divider{height:1px;background:var(--color-border);margin:1.25rem 0}.landing-divider-text{display:flex;align-items:center;gap:1rem;margin:1.25rem 0;color:var(--color-text-muted);font-size:.85rem}.landing-divider-text:before,.landing-divider-text:after{content:"";flex:1;height:1px;background:var(--color-border)}.landing-sso-buttons{display:flex;flex-direction:column;gap:.5rem}.landing-btn-sso{display:block;width:100%;padding:.65rem 1rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;text-align:center;text-decoration:none;cursor:pointer;transition:background .15s,border-color .15s;box-sizing:border-box}.landing-btn-google{background:#fff;color:#3c4043;border-color:#dadce0}.landing-btn-google:hover{background:#f7f8f8;border-color:#c0c3c7}.landing-btn-facebook{background:#1877f2;color:#fff;border-color:#1877f2}.landing-btn-facebook:hover{background:#166fe5}.landing-btn-microsoft{background:#2f2f2f;color:#fff;border-color:#2f2f2f}.landing-btn-microsoft:hover{background:#1a1a1a}.landing-card-footer{text-align:center}.landing-btn-create{padding:.75rem 1.5rem;background:var(--color-success);color:#fff;border:none;border-radius:var(--radius-sm);font-size:1.05rem;font-weight:700;cursor:pointer;transition:background .15s}.landing-btn-create:hover{background:var(--color-success-hover)}.landing-btn-back{padding:.6rem 1.5rem;background:none;color:var(--color-primary);border:2px solid var(--color-primary);border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.landing-btn-back:hover{background:var(--color-primary);color:#fff}.landing-footer{text-align:center;padding:1.5rem 1rem;color:var(--color-text-muted);font-size:.85rem}.landing-footer p{margin:0}.landing-footer-links{display:flex;justify-content:center;gap:1.5rem;margin-top:.5rem}.landing-footer-link{color:var(--color-text-muted);font-size:.8rem;text-decoration:underline}.landing-footer-link:hover{color:var(--color-primary)}.landing-version{margin-top:.75rem;font-size:.65rem;opacity:.35;font-family:monospace;letter-spacing:.02em}.privacy-page{max-width:720px;margin:0 auto;line-height:1.7}.privacy-page h1{margin-bottom:.25rem}.privacy-updated{color:var(--color-text-muted);font-size:.85rem;margin-bottom:2rem}.privacy-section{margin-bottom:2rem}.privacy-section h2{font-size:1.15rem;margin-bottom:.5rem}.privacy-section p{margin-bottom:.75rem}.privacy-section ul{margin:.5rem 0;padding-left:1.5rem}.privacy-section li{margin-bottom:.4rem}@media(max-width:900px){.landing-container{flex-direction:column;gap:2rem;padding:3rem 1.5rem 2rem;text-align:center}.landing-left{flex:none;max-width:500px}.landing-features{justify-content:center}.landing-right{flex:none;width:100%;max-width:420px;min-width:0}}@media(max-width:480px){.landing-container{padding:2rem 1rem}.landing-card{padding:1.25rem}.landing-right{max-width:100%}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}.loading-text{text-align:center;padding:3rem 1rem;font-size:.95rem;font-weight:500;color:var(--color-text-muted);background:linear-gradient(90deg,var(--color-text-muted) 0%,var(--color-primary) 50%,var(--color-text-muted) 100%);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 1.8s ease-in-out infinite}.practice-answer{animation:fade-in .3s ease-out}.test-feedback{animation:fade-in-up .3s ease-out}.session-detail{animation:fade-in .25s ease-out}.landing-card{transition:box-shadow .3s ease}.landing-card:hover{box-shadow:var(--shadow-xl),0 0 0 1px rgba(var(--color-primary-rgb),.05)}.import-dropzone{transition:border-color .25s,background .25s,transform .2s}.import-dropzone.dragging{transform:scale(1.01)}.snackbar{position:fixed;bottom:1.5rem;left:50%;transform:translate(-50%);background:var(--color-danger);color:#fff;padding:.75rem 1.5rem;border-radius:var(--radius-full);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-lg);z-index:9999;cursor:pointer;animation:snackbar-in .3s ease-out;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}@keyframes snackbar-in{0%{opacity:0;transform:translate(-50%) translateY(1rem)}to{opacity:1;transform:translate(-50%) translateY(0)}}.cookie-consent{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1.5rem;background:var(--color-surface);border-top:1px solid var(--color-border);box-shadow:0 -2px 8px #0000001a;z-index:200;font-size:.9rem}.cookie-consent p{margin:0}.cookie-consent-btn{padding:.4rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);cursor:pointer;white-space:nowrap;font-size:.85rem}.landing-consent{display:flex;align-items:flex-start;gap:.5rem;font-size:.85rem;color:var(--color-text-muted)}.landing-consent input[type=checkbox]{margin-top:.2rem}.landing-consent a{color:var(--color-primary);text-decoration:underline}.navbar-avatar{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:rgba(var(--color-primary-rgb),.15);color:var(--color-primary);font-size:.85rem;font-weight:700;text-decoration:none;transition:all .2s cubic-bezier(.22,1,.36,1)}.navbar-avatar:hover{background:rgba(var(--color-primary-rgb),.25);transform:scale(1.05)}.account-page{max-width:720px}.account-layout{display:flex;gap:2rem;margin-top:1.5rem}.account-sidebar{display:flex;flex-direction:column;gap:.25rem;min-width:180px;flex-shrink:0}.account-sidebar-item{display:block;width:100%;padding:.6rem 1rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text);font-size:.95rem;font-weight:500;text-align:left;cursor:pointer;transition:background .15s,color .15s}.account-sidebar-item:hover{background:var(--color-border)}.account-sidebar-item.active{background:var(--color-primary);color:#fff}.account-content{flex:1;min-width:0}.account-section h2{margin:0 0 1rem;font-size:1.15rem}.account-section h3{font-size:1.05rem;margin:0 0 .5rem}.account-email{color:var(--color-text-muted);margin-bottom:1.5rem}.account-credits{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.account-credits-value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.credits-transaction-table{width:100%;border-collapse:collapse;margin-top:.5rem;font-size:.9rem}.credits-transaction-table th,.credits-transaction-table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--color-border)}.credits-transaction-table th{font-weight:600;color:var(--color-text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.credits-positive{color:var(--color-success, #16a34a);font-weight:600}.credits-negative{color:var(--color-danger, #dc2626);font-weight:600}.account-password-form{display:flex;flex-direction:column;gap:.75rem;max-width:340px}.account-password-form input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-bg);color:var(--color-text)}.account-msg{font-size:.9rem;margin:0;padding:.5rem .75rem;border-radius:var(--radius-sm)}.account-msg-error{color:var(--color-danger, #dc2626);background:#dc262614}.account-msg-success{color:var(--color-success, #16a34a);background:#16a34a14}.account-danger-zone{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--color-border)}.account-delete-confirm{background:var(--color-surface);border:1px solid var(--color-danger, #dc3545);border-radius:var(--radius-md);padding:1.5rem}.account-delete-warning{color:var(--color-text-muted);font-size:.9rem;margin-bottom:1rem}.account-delete-label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.4rem}.account-delete-confirm input{width:100%;padding:.5rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-bg);color:var(--color-text);margin-bottom:1rem}.account-delete-actions{display:flex;gap:.75rem}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg, 0 8px 32px rgba(0, 0, 0, .22));padding:2rem;width:100%;max-width:560px;max-height:90vh;overflow-y:auto;display:flex;flex-direction:column;gap:1.25rem}.modal-title{font-size:1.25rem;font-weight:700;margin:0;color:var(--color-text)}.modal-subtitle{font-size:1rem;font-weight:600;margin:0 0 .75rem;color:var(--color-text)}.modal-label{display:block;font-size:.9rem;font-weight:500;margin-bottom:.35rem;color:var(--color-text)}.modal-body{display:flex;flex-direction:column;gap:.75rem}.modal-body.modal-loading{align-items:center;padding:2rem 0;color:var(--color-text-muted)}.modal-actions{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.25rem}.generate-textarea{width:100%;padding:.6rem .75rem;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--color-bg);color:var(--color-text);resize:vertical;font-family:inherit;line-height:1.5;box-sizing:border-box}.generate-textarea:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px rgba(var(--color-primary-rgb),.15)}.generate-file-input{font-size:.875rem;color:var(--color-text-muted)}.generate-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius-md);padding:.75rem;transition:border-color .2s,background .2s}.generate-dropzone.dragging{border-color:var(--color-primary);background:var(--color-primary-light)}.generate-file-row{display:flex;align-items:center;gap:.75rem;margin-top:.5rem}.generate-file-btn{cursor:pointer;flex-shrink:0}.generate-file-hidden{display:none}.generate-drop-hint{font-size:.8rem;color:var(--color-text-muted)}.generate-file-name{font-size:.85rem;color:var(--color-primary);margin:.4rem 0 0}.generate-credit-notice{font-size:.82rem;color:var(--color-text-muted);margin:0}.generate-word-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.4rem;max-height:340px;overflow-y:auto;border:1px solid var(--color-border-light);border-radius:var(--radius-sm);padding:.5rem .75rem;background:var(--color-bg)}.generate-word-item{display:flex;align-items:flex-start}.generate-word-label{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;font-size:.9rem;line-height:1.4}.generate-word-label input[type=checkbox]{margin-top:.2rem;flex-shrink:0;accent-color:var(--color-primary)}.generate-word-text{color:var(--color-text)}.generate-example{color:var(--color-text-muted);font-size:.82rem}.generate-none{color:var(--color-text-muted);font-size:.9rem;margin:0}.generate-error{color:var(--color-danger);font-size:.9rem;margin:0}.glossary-generate-row{padding:.4rem 1rem;border-bottom:1px solid var(--color-border-light)}.concept-generate-row{padding:.4rem 0;margin-bottom:1rem}@media(max-width:768px){.account-layout{flex-direction:column;gap:1rem}.account-sidebar{flex-direction:row;min-width:0;overflow-x:auto;gap:.5rem;padding-bottom:.25rem}.account-sidebar-item{white-space:nowrap;width:auto;padding:.5rem .85rem;font-size:.9rem}}
