*{margin:0;padding:0;box-sizing:border-box}body{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;margin:0;background:#f5f7fa;color:#333}#root{min-height:100vh}.navigation{background:#667eea;color:#fff;padding:1rem 0;box-shadow:0 2px 4px #0000001a}.nav-container{max-width:1400px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.nav-brand{font-size:1.5rem;font-weight:700;color:#fff;text-decoration:none}.nav-links{display:flex;align-items:center;gap:1.5rem}.nav-link{color:#fff;text-decoration:none;font-weight:500;transition:opacity .2s}.nav-link:hover{opacity:.8}.user-info{display:flex;align-items:center;gap:1rem}.btn-logout{padding:.5rem 1rem;background:#fff3;color:#fff;border:1px solid white;border-radius:4px;cursor:pointer;font-weight:500;transition:background .2s}.btn-logout:hover{background:#ffffff4d}@media(max-width:768px){.nav-container{flex-direction:column;gap:1rem}.nav-links{flex-direction:column;gap:.75rem}.user-info{flex-direction:column;gap:.5rem}}.home{min-height:calc(100vh - 80px)}.hero{text-align:center;padding:4rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.hero h1{font-size:3rem;margin-bottom:1rem}.hero p{font-size:1.5rem;margin-bottom:2rem}.cta-buttons{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-cta,.btn-cta-secondary{padding:1rem 2rem;border-radius:8px;font-size:1.125rem;font-weight:600;text-decoration:none;transition:transform .2s}.btn-cta{background:#fff;color:#667eea}.btn-cta-secondary{background:#fff3;color:#fff;border:2px solid white}.btn-cta:hover,.btn-cta-secondary:hover{transform:translateY(-2px)}.features{max-width:1200px;margin:4rem auto;padding:0 2rem;display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.feature{text-align:center;padding:2rem;background:#fff;border-radius:8px;box-shadow:0 4px 8px #0000001a}.feature h3{font-size:1.5rem;margin-bottom:1rem;color:#667eea}.feature p{color:#666;line-height:1.6}@media(max-width:768px){.hero h1{font-size:2rem}.hero p{font-size:1.125rem}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.auth-card{background:#fff;padding:2rem;border-radius:10px;box-shadow:0 10px 30px #0000001a;width:100%;max-width:400px}.auth-card h1{text-align:center;color:#667eea;margin-bottom:.5rem}.auth-card h2{text-align:center;color:#333;margin-bottom:1.5rem}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:5px;font-size:1rem;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#667eea}button{width:100%;padding:.75rem;background:#667eea;color:#fff;border:none;border-radius:5px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .3s}button:hover:not(:disabled){background:#5568d3}button:disabled{background:#ccc;cursor:not-allowed}.error-message{background:#fee;color:#c33;padding:.75rem;border-radius:5px;margin-bottom:1rem;border:1px solid #fcc}.auth-link{text-align:center;margin-top:1rem;color:#555}.auth-link a{color:#667eea;text-decoration:none;font-weight:600}.auth-link a:hover{text-decoration:underline}.admin-users{padding:2rem;max-width:1200px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.header h1{color:#333;margin:0}.users-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #0000001a;border-radius:8px;overflow:hidden}.users-table thead{background:#667eea;color:#fff}.users-table th,.users-table td{padding:1rem;text-align:left}.users-table tbody tr:hover{background:#f5f5f5}.status{padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:500}.status.active{background:#d4edda;color:#155724}.status.inactive{background:#f8d7da;color:#721c24}.actions{display:flex;gap:.5rem}.btn-primary,.btn-secondary,.btn-edit,.btn-warning,.btn-success,.btn-danger{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;font-weight:500;transition:opacity .2s}.btn-primary{background:#667eea;color:#fff}.btn-primary:hover{opacity:.9}.btn-secondary{background:#6c757d;color:#fff}.btn-edit{background:#17a2b8;color:#fff}.btn-warning{background:#ffc107;color:#333}.btn-success{background:#28a745;color:#fff}.btn-danger{background:#dc3545;color:#fff}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal{background:#fff;padding:2rem;border-radius:8px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto}.modal h2{margin-top:0;color:#333}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#555;font-weight:500}.form-group input,.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.modal-actions{display:flex;gap:1rem;margin-top:1.5rem}.modal-actions button{flex:1}.loading,.error{text-align:center;padding:2rem;font-size:1.125rem}.error{color:#dc3545}.lesson-processing-status{padding:16px;border:1px solid #e5e7eb;border-radius:8px;background-color:#fff;box-shadow:0 1px 3px #0000001a}.status-header{display:flex;align-items:flex-start;gap:12px}.status-info{flex:1}.lesson-status.loading{display:flex;align-items:center;gap:8px;padding:16px;color:#6b7280}.spinner{width:16px;height:16px;border:2px solid #e5e7eb;border-top:2px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite}.workspace{padding:1.5rem;max-width:1600px;margin:0 auto;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif}.workspace-header{text-align:center;margin-bottom:2rem;padding:2rem;background:#fffffff2;border-radius:20px;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.workspace-header h1{color:#4a5568;font-size:2.5rem;margin-bottom:1rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.1)}.welcome-message{color:#718096;font-size:1.2rem;margin:0;font-weight:500}.workspace-content{display:flex;flex-direction:column;gap:2rem}.workspace-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:2rem}.section{background:#fffffff2;border-radius:20px;box-shadow:0 8px 32px #0000001a;padding:2rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:transform .3s ease,box-shadow .3s ease}.section:hover{transform:translateY(-2px);box-shadow:0 12px 40px #00000026}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:3px solid #e2e8f0}.section-title{display:flex;align-items:center;gap:.75rem}.section-icon{font-size:2rem;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.1))}.section-header h2{margin:0;color:#2d3748;font-size:1.5rem;font-weight:700}.btn-add-primary,.btn-add-secondary,.btn-add-accent,.btn-add-compact{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:50px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003}.btn-add-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-add-secondary{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff}.btn-add-accent{background:linear-gradient(135deg,#4facfe,#00f2fe);color:#fff}.btn-add-compact{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.6rem 1.2rem;font-size:.95rem;width:auto;min-width:130px;white-space:nowrap}.btn-add-primary:hover,.btn-add-secondary:hover,.btn-add-accent:hover,.btn-add-compact:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.grade-card,.subject-card{background:linear-gradient(135deg,#fff,#f8fafc);border:3px solid transparent;border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative;box-shadow:0 4px 15px #0000001a}.grade-card:hover,.subject-card:hover{transform:translateY(-4px);box-shadow:0 8px 25px #00000026;border-color:#667eea}.grade-card.selected{border-color:#667eea;background:linear-gradient(135deg,#e6fffa 0% 100%);box-shadow:0 8px 25px #667eea40}.subject-card.selected{border-color:#f093fb;background:linear-gradient(135deg,#fef5e7 0% 100%);box-shadow:0 8px 25px #f093fb40}.card-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.grade-icon,.subject-icon{font-size:2.5rem;filter:drop-shadow(2px 2px 4px rgba(0,0,0,.1))}.card-header h3{margin:0;color:#2d3748;font-size:1.25rem;font-weight:700}.card-content p{margin:0 0 1rem;color:#4a5568;font-size:.95rem;line-height:1.5}.subjects-count,.lessons-count{color:#718096;font-size:.9rem;font-weight:600;background:#667eea1a;padding:.25rem .75rem;border-radius:20px;display:inline-block}.lessons-list{display:flex;flex-direction:column;gap:1.5rem}.lesson-card{background:linear-gradient(135deg,#fff,#f8fafc);border:2px solid #e2e8f0;border-radius:16px;padding:1.5rem;transition:all .3s ease;box-shadow:0 4px 15px #0000001a}.lesson-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #00000026;border-color:#4facfe}.lesson-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.lesson-number{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.9rem}.lesson-header h3{margin:0;color:#2d3748;font-size:1.2rem;font-weight:700;flex:1;min-width:200px}.lesson-content p{margin:0 0 1rem;color:#4a5568;line-height:1.5}.lesson-meta{margin-bottom:1rem}.file-info{color:#718096;font-size:.9rem;background:#4a55681a;padding:.5rem 1rem;border-radius:15px;display:inline-block}.lesson-actions{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:flex-start}.btn-study,.btn-download,.btn-delete-lesson{display:flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border:none;border-radius:20px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:.95rem;box-shadow:0 2px 8px #00000026;min-width:120px;max-width:fit-content;white-space:nowrap;flex-shrink:0}.btn-study{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-download{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.btn-delete-lesson{background:linear-gradient(135deg,#ff416c,#ff4b2b);color:#fff}.btn-study:hover,.btn-download:hover,.btn-delete-lesson:hover{transform:translateY(-1px);box-shadow:0 4px 12px #00000040}.btn-delete-small{position:absolute;top:1rem;right:1rem;background:linear-gradient(135deg,#ff416c,#ff4b2b);color:#fff;border:none;border-radius:50%;width:40px;height:40px;cursor:pointer;font-size:1.1rem;transition:all .3s ease;box-shadow:0 4px 15px #ff416c4d}.btn-delete-small:hover{transform:scale(1.1);box-shadow:0 6px 20px #ff416c80}.empty-state{text-align:center;padding:3rem 1rem;color:#718096}.empty-icon{font-size:4rem;display:block;margin-bottom:1rem;filter:grayscale(50%)}.empty-state p{font-size:1.1rem;font-weight:500;margin:0}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px)}.kid-friendly-modal{background:linear-gradient(135deg,#fff,#f8fafc);padding:2.5rem;border-radius:20px;width:100%;max-width:600px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;border:1px solid rgba(255,255,255,.2)}.modal-header{text-align:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:3px solid #e2e8f0}.modal-header h2{margin:0 0 .5rem;color:#2d3748;font-size:1.8rem;font-weight:700}.modal-header p{margin:0;color:#718096;font-size:1.1rem}.form-group{margin-bottom:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:#2d3748;font-weight:600;font-size:1rem}.form-group input,.form-group textarea{width:100%;padding:1rem;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;font-family:inherit;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group textarea{min-height:100px;resize:vertical}.file-input{padding:.75rem!important;background:#f7fafc;cursor:pointer}.file-preview{margin-top:.75rem;padding:.75rem;background:#667eea1a;border-radius:8px;color:#2d3748;font-weight:500}.modal-actions{display:flex;gap:1rem;margin-top:2rem}.btn-modal-primary,.btn-modal-secondary{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:1rem 2rem;border:none;border-radius:25px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003}.btn-modal-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-modal-secondary{background:linear-gradient(135deg,#a8a8a8,#8e8e8e);color:#fff}.btn-modal-primary:hover,.btn-modal-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.status-badge{padding:.4rem .8rem;border-radius:20px;font-size:.85rem;font-weight:600;display:inline-flex;align-items:center;gap:.3rem;margin-left:auto}.status-badge.success{background:linear-gradient(135deg,#10b981,#059669);color:#fff;box-shadow:0 2px 8px #10b9814d}.status-badge.processing{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 8px #f59e0b4d}.status-badge.error{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 8px #ef44444d}.processing-status-container{margin:1rem 0;padding:1rem;background:#667eea0d;border-radius:12px;border-left:4px solid #667eea}.error-message{margin:1rem 0;padding:1rem;background:#ef44441a;border-radius:12px;border-left:4px solid #ef4444;color:#dc2626;font-weight:500}.btn-study.disabled{background:linear-gradient(135deg,#a8a8a8,#8e8e8e);cursor:not-allowed;opacity:.6}.btn-study.disabled:hover{transform:none;box-shadow:0 2px 8px #00000026}.section.full-width,.lessons-section.full-width{grid-column:1 / -1;width:100%}@media(max-width:1024px){.workspace-content{grid-template-columns:1fr}.cards-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr))}}@media(max-width:768px){.workspace{padding:1rem}.workspace-header h1{font-size:2rem}.welcome-message{font-size:1rem}.section{padding:1.5rem}.section-header{flex-direction:column;gap:1rem;align-items:stretch}.lesson-actions{gap:.5rem;justify-content:flex-start}.btn-study,.btn-download,.btn-delete-lesson{flex:0 0 auto;min-width:110px;padding:.5rem 1rem;font-size:.9rem}.modal-actions{flex-direction:column}.cards-grid{grid-template-columns:1fr}}@media(max-width:480px){.workspace-header{padding:1.5rem}.workspace-header h1{font-size:1.8rem}.kid-friendly-modal{padding:1.5rem;margin:1rem}}.lesson-viewer{max-width:1800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.lesson-header{margin-bottom:30px;border-bottom:2px solid #e5e5e5;padding-bottom:15px}.lesson-title{color:#2c3e50;font-size:2rem;font-weight:600;margin:0;display:flex;align-items:center;gap:15px}.lesson-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;font-weight:500}.section-content{background:#fff;border-radius:12px;padding:40px;box-shadow:0 4px 20px #0000001a}.section-heading{color:#34495e;font-size:2rem;font-weight:600;margin:0 0 30px;border-left:4px solid #3498db;padding-left:20px}.section-body{margin-bottom:30px;display:grid;grid-template-columns:1fr 650px;gap:50px;align-items:start}.section-body-left{display:flex;flex-direction:column;gap:30px}.section-body-right{position:sticky;top:20px}.markdown-content{line-height:1.8;color:#2c3e50;font-size:1.1rem}.markdown-content p{margin-bottom:18px;color:#4a5568;line-height:1.8}.markdown-content h1,.markdown-content h2,.markdown-content h3,.markdown-content h4,.markdown-content h5,.markdown-content h6{color:#2d3748;margin-bottom:14px;margin-top:26px}.markdown-content ul,.markdown-content ol{margin-bottom:18px;padding-left:24px}.markdown-content li{margin-bottom:6px;color:#4a5568}.markdown-content strong{font-weight:600;color:#2d3748}.markdown-content em{font-style:italic;color:#4a5568}.markdown-content code{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:4px;font-family:Monaco,Consolas,Liberation Mono,monospace;font-size:.95em;padding:3px 8px;color:#e53e3e}.markdown-content pre{background-color:#f7fafc;border:1px solid #e2e8f0;border-radius:8px;padding:20px;overflow-x:auto;margin-bottom:18px;font-family:Monaco,Consolas,Liberation Mono,monospace;font-size:.95em;line-height:1.6}.markdown-content blockquote{border-left:4px solid #3182ce;background-color:#ebf8ff;padding:16px 20px;margin:20px 0;font-style:italic;color:#2a4365}.markdown-content table{border-collapse:collapse;width:100%;margin:20px 0;border:1px solid #e2e8f0}.markdown-content th,.markdown-content td{border:1px solid #e2e8f0;padding:14px;text-align:left}.markdown-content th{background-color:#f7fafc;font-weight:600;color:#2d3748}.lesson-images{background:#f8f9fa;border:1px solid #dee2e6;border-radius:15px;padding:30px;width:100%}.lesson-images h4{margin:0 0 25px;color:#495057;font-size:1.3rem;font-weight:600;display:flex;align-items:center;gap:10px}.image-gallery{display:flex;flex-direction:column;gap:30px}.image-container{display:flex;flex-direction:column;align-items:center}.image-wrapper{width:100%;border-radius:15px;overflow:hidden;box-shadow:0 8px 25px #00000026;background:#fff;transition:transform .3s ease,box-shadow .3s ease}.image-wrapper:hover{transform:translateY(-8px);box-shadow:0 15px 40px #00000040}.lesson-image{width:100%;height:auto;max-height:700px;object-fit:contain;display:block;transition:transform .3s ease}.lesson-image:hover{transform:scale(1.03)}.image-caption{background:#495057;color:#fff;padding:15px 20px;font-size:1rem;font-weight:500;text-align:center;border-bottom-left-radius:15px;border-bottom-right-radius:15px}.image-placeholder{width:100%;height:400px;border:3px dashed #dee2e6;border-radius:15px;display:flex;align-items:center;justify-content:center;background:#f8f9fa}.image-placeholder-content{display:flex;flex-direction:column;align-items:center;gap:15px;color:#6c757d;text-align:center}.image-placeholder-icon{font-size:4rem;opacity:.7}.image-placeholder-text{font-size:1.1rem;font-weight:500}.no-images-placeholder{background:transparent;border:none;display:none}.image-references{background:#f8f9fa;border:1px solid #dee2e6;border-radius:8px;padding:20px;margin:25px 0}.image-references h4{margin:0 0 15px;color:#495057;font-size:1.1rem;font-weight:600}.image-tags{display:flex;flex-wrap:wrap;gap:10px}.image-tag{background:#e9ecef;color:#495057;padding:6px 12px;border-radius:15px;font-size:.9rem;font-weight:500}.vocabulary-box{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:15px;padding:30px;color:#fff}.vocabulary-box h4{margin:0 0 25px;color:#fff;font-size:1.3rem;font-weight:600}.vocabulary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:15px;margin-bottom:25px}.vocab-word{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.3);padding:15px 20px;border-radius:10px;cursor:pointer;transition:all .3s ease;font-weight:500;font-size:1rem}.vocab-word:hover{background:#ffffff4d;border-color:#fff9;transform:translateY(-3px)}.vocab-word.selected{background:#fff;color:#667eea;border-color:#fff;font-weight:600}.vocab-tooltip{background:#fffffff2;border-radius:12px;padding:25px;margin-top:20px;box-shadow:0 6px 20px #00000026}.vocab-tooltip-content{color:#2c3e50}.vocab-word-title{font-size:1.2rem;font-weight:600;color:#667eea;display:block;margin-bottom:10px}.vocab-explanation{color:#4a5568;font-size:1rem}.vocab-explanation p{margin:10px 0;line-height:1.7}.vocab-explanation code{background-color:#f1f5f9;color:#1e293b}.section-progress{margin:40px 0;grid-column:1 / -1}.progress-bar{background:#e9ecef;height:10px;border-radius:5px;overflow:hidden;margin-bottom:12px}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .3s ease;border-radius:5px}.progress-text{text-align:center;color:#6c757d;font-size:1rem;margin:0;font-weight:500}.navigation-buttons{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:40px;grid-column:1 / -1}.btn-nav,.btn-practice{padding:15px 30px;border:none;border-radius:10px;font-weight:600;font-size:1.1rem;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;min-width:150px}.btn-nav{background:#f8f9fa;color:#495057;border:2px solid #dee2e6}.btn-nav:hover:not(:disabled){background:#e9ecef;transform:translateY(-3px);box-shadow:0 6px 15px #0003}.btn-nav:disabled{opacity:.6;cursor:not-allowed}.btn-practice{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;flex-shrink:0}.btn-practice:hover{transform:translateY(-3px);box-shadow:0 8px 25px #28a74566}.btn-next{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-next:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 8px 25px #667eea66}@media(max-width:1600px){.lesson-viewer{max-width:1400px}.section-body{grid-template-columns:1fr 550px}.lesson-image{max-height:600px}}@media(max-width:1400px){.lesson-viewer{max-width:1200px}.section-body{grid-template-columns:1fr 500px}.lesson-image{max-height:500px}.image-placeholder{height:350px}}@media(max-width:1024px){.section-body{grid-template-columns:1fr;gap:30px}.section-body-right{position:static}.lesson-images{order:-1}.image-gallery{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:25px}.lesson-image{max-height:450px}.image-placeholder{height:300px}}@media(max-width:768px){.lesson-viewer{padding:15px}.lesson-title{font-size:1.5rem;flex-direction:column;align-items:flex-start;gap:10px}.section-content{padding:25px}.image-gallery{grid-template-columns:1fr;gap:20px}.lesson-image{max-height:350px}.image-placeholder{height:250px}.image-placeholder-icon{font-size:2.5rem}.vocabulary-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.navigation-buttons{flex-direction:column;gap:15px}.btn-nav,.btn-practice{width:100%;padding:16px}}.practice-game{max-width:800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f8f9fa;min-height:100vh}.no-questions{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.no-questions h2{color:#495057;margin-bottom:30px;font-size:1.8rem;font-weight:600}.game-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:25px 30px;background:linear-gradient(135deg,#4a90e2,#6a5acd);border-radius:15px;color:#fff;box-shadow:0 6px 25px #4a90e24d}.game-header h2{margin:0;font-size:2rem;font-weight:700;color:#fff!important;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:.5px}.score-display{font-size:1.1rem;font-weight:600;background:#ffffff40;color:#000!important;padding:10px 18px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);text-shadow:none}.question-card{background:#fff;border-radius:15px;padding:35px;box-shadow:0 6px 30px #00000026;margin-bottom:25px;transition:all .3s ease;border:1px solid #e9ecef;color:#212529}.question-card.feedback-correct{border:3px solid #28a745;box-shadow:0 8px 35px #28a74540}.question-card.feedback-incorrect{border:3px solid #dc3545;box-shadow:0 8px 35px #dc354540}.question-number{display:grid;grid-template-columns:1fr auto;align-items:center;margin-bottom:25px;color:#fff!important;font-weight:600;font-size:1rem;text-shadow:0 1px 2px rgba(0,0,0,.3);width:100%;padding:15px 25px;background:linear-gradient(135deg,#4a90e2,#6a5acd);border-radius:10px;box-shadow:0 4px 15px #4a90e24d;gap:20px}.question-number>span:first-child{font-weight:700;justify-self:start;color:#fff!important}.question-number>span{color:#fff!important}.question-type{background:#ffffff40;padding:6px 12px;border-radius:20px;font-size:.75rem;color:#fff!important;font-weight:600;border:1px solid rgba(255,255,255,.3);text-shadow:0 1px 2px rgba(0,0,0,.2);white-space:nowrap;text-align:center;justify-self:end}.question-text{color:#212529!important;font-size:1.4rem;font-weight:600;margin-bottom:30px;line-height:1.6;text-align:left;text-shadow:none}.answer-input{margin-bottom:25px}.multiple-choice-options{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.option-label{display:flex;align-items:center;padding:18px 20px;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;transition:all .3s ease;background:#fafafa;color:#495057}.option-label:hover{border-color:#4a90e2;background:#f0f7ff;transform:translateY(-1px);box-shadow:0 4px 15px #4a90e226}.option-label input[type=radio]{margin-right:15px;transform:scale(1.3);accent-color:#4a90e2}.option-label input[type=radio]:checked+.option-text{font-weight:700;color:#4a90e2}.option-label:has(input[type=radio]:checked){border-color:#4a90e2;background:#f0f7ff;box-shadow:0 4px 15px #4a90e233}.option-text{font-size:1.1rem;color:#495057;line-height:1.4}.answer-textarea{width:100%;padding:18px 20px;border:2px solid #e9ecef;border-radius:10px;font-size:1.1rem;font-family:inherit;resize:vertical;transition:border-color .3s ease;background:#fafafa;color:#495057;line-height:1.5}.answer-textarea:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 4px #4a90e21a;background:#fff}.answer-textarea::placeholder{color:#6c757d;opacity:.8}.btn-submit{background:linear-gradient(135deg,#4a90e2,#6a5acd);color:#fff;padding:14px 35px;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.2);box-shadow:0 4px 15px #4a90e24d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 25px #4a90e266}.answer-reveal{margin-top:25px}.your-answer,.correct-answer,.explanation{margin-bottom:25px;padding:20px;border-radius:10px;border-left:5px solid}.your-answer{background:linear-gradient(135deg,#e3f2fd,#f0f7ff);border-left-color:#2196f3}.correct-answer{background:linear-gradient(135deg,#e8f5e8,#f0fff0);border-left-color:#4caf50}.explanation{background:linear-gradient(135deg,#fff8e1,#fffde7);border-left:5px solid #ffa726;border-radius:12px;padding:25px;margin:20px 0;box-shadow:0 4px 20px #ffa72633;position:relative}.explanation h4{margin:0 0 15px;color:#e65100;font-size:1.3rem;font-weight:700;display:flex;align-items:center;gap:8px}.explanation h4:before{content:"💡";font-size:1.2em}.explanation-content.markdown-content{color:#3e2723;line-height:1.8;font-size:1.1rem;margin-top:10px}.explanation-content.markdown-content strong{font-weight:700;color:#d84315;background:#ffa7261a;padding:2px 4px;border-radius:4px}.explanation-content.markdown-content code{background-color:#fff3e0;border:1px solid #ffcc02;border-radius:6px;font-family:Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:.95em;padding:4px 8px;color:#e65100;font-weight:600}.markdown-content ul,.markdown-content ol{margin:12px 0;padding-left:25px}.markdown-content li{margin-bottom:6px;color:#495057;line-height:1.6}.self-check{background:linear-gradient(135deg,#f8f9fa,#fff);padding:25px;border-radius:12px;text-align:center;border:2px dashed #dee2e6;margin-top:20px}.self-check p{margin:0 0 18px;color:#495057;font-weight:600;font-size:1.1rem}.btn-correct,.btn-incorrect{padding:12px 24px;border:none;border-radius:10px;font-weight:700;cursor:pointer;transition:all .3s ease;font-size:1rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.btn-correct{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;box-shadow:0 4px 15px #28a7454d}.btn-correct:hover{background:linear-gradient(135deg,#218838,#1ea085);transform:translateY(-2px);box-shadow:0 6px 20px #28a74566}.btn-incorrect{background:linear-gradient(135deg,#dc3545,#e74c3c);color:#fff;box-shadow:0 4px 15px #dc35454d}.btn-incorrect:hover{background:linear-gradient(135deg,#c82333,#dc2f2a);transform:translateY(-2px);box-shadow:0 6px 20px #dc354566}.feedback-animation{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:linear-gradient(135deg,#fff,#f8f9fa);padding:40px 60px;border-radius:20px;box-shadow:0 20px 60px #0000004d;font-size:2rem;font-weight:800;z-index:1000;animation:feedbackBurst 3s ease-in-out;text-align:center;pointer-events:none;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:4px solid;min-width:350px;max-width:500px}.correct-animation{color:#28a745;border-color:#28a745;background:linear-gradient(135deg,#d4edda,#c3e6cb);animation:correctBurst 3s ease-in-out;text-shadow:0 2px 4px rgba(40,167,69,.3)}.incorrect-animation{color:#dc3545;border-color:#dc3545;background:linear-gradient(135deg,#f8d7da,#f5c6cb);animation:incorrectShake 3s ease-in-out;text-shadow:0 2px 4px rgba(220,53,69,.3)}@keyframes correctBurst{0%{transform:translate(-50%,-50%) scale(.5) rotate(-10deg);opacity:0;filter:brightness(.8)}15%{transform:translate(-50%,-50%) scale(1.2) rotate(2deg);opacity:1;filter:brightness(1.2)}25%{transform:translate(-50%,-50%) scale(1.1) rotate(-1deg);opacity:1;filter:brightness(1.1)}35%{transform:translate(-50%,-50%) scale(1.05) rotate(.5deg);opacity:1;filter:brightness(1)}85%{transform:translate(-50%,-50%) scale(1) rotate(0);opacity:1;filter:brightness(1)}to{transform:translate(-50%,-50%) scale(.8) rotate(0);opacity:0;filter:brightness(.9)}}@keyframes incorrectShake{0%{transform:translate(-50%,-50%) scale(.5);opacity:0;filter:brightness(.8)}10%{transform:translate(-50%,-50%) scale(1.1) translate(-10px);opacity:1;filter:brightness(1.1)}15%{transform:translate(-50%,-50%) scale(1.1) translate(10px);opacity:1}20%{transform:translate(-50%,-50%) scale(1.05) translate(-8px);opacity:1}25%{transform:translate(-50%,-50%) scale(1.05) translate(8px);opacity:1}30%{transform:translate(-50%,-50%) scale(1) translate(-5px);opacity:1}35%{transform:translate(-50%,-50%) scale(1) translate(5px);opacity:1}40%{transform:translate(-50%,-50%) scale(1) translate(0);opacity:1;filter:brightness(1)}85%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.8);opacity:0;filter:brightness(.9)}}@keyframes feedbackPulse{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}15%{transform:translate(-50%,-50%) scale(1.1);opacity:1}35%{transform:translate(-50%,-50%) scale(1);opacity:1}85%{transform:translate(-50%,-50%) scale(1);opacity:1}to{transform:translate(-50%,-50%) scale(.9);opacity:0}}.correct-animation:before,.correct-animation:after{content:"";position:absolute;width:8px;height:8px;background:#28a745;border-radius:50%;animation:confettiFloat 3s ease-out}.correct-animation:before{top:20%;left:20%;animation-delay:.2s;background:linear-gradient(45deg,#28a745,#20c997)}.correct-animation:after{top:30%;right:25%;animation-delay:.4s;background:linear-gradient(45deg,#ffc107,#fd7e14)}@keyframes confettiFloat{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(-100px) rotate(360deg);opacity:0}}.feedback-animation{position:relative;overflow:visible}.correct-animation{box-shadow:0 20px 60px #0000004d,0 0 0 4px #28a7454d,0 0 30px #28a74580}.incorrect-animation{box-shadow:0 20px 60px #0000004d,0 0 0 4px #dc35454d,0 0 30px #dc354580}.game-complete{text-align:center;padding:45px;background:#fff;border-radius:20px;box-shadow:0 8px 40px #0000001f;border:1px solid #e9ecef}.game-complete h2{color:#212529;font-size:2.5rem;margin-bottom:35px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}.score-circle{display:inline-flex;align-items:center;justify-content:center;width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,#4a90e2,#6a5acd);color:#fff;margin-bottom:25px;box-shadow:0 8px 30px #4a90e24d}.score-number{font-size:2.2rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.3)}.score-text{color:#495057;font-size:1.3rem;margin:0;font-weight:600}.encouragement{color:#495057;font-size:1.2rem;font-style:italic;margin:25px 0;font-weight:500}.game-actions{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.game-footer{text-align:center;margin-top:30px}.next-question-section{text-align:center;margin-top:25px;padding-top:20px;border-top:2px dashed #dee2e6}.btn-next-question{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:15px 30px;border:none;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 6px 20px #28a7454d;display:flex;align-items:center;justify-content:center;gap:8px;margin:0 auto;min-width:200px}.btn-next-question:hover{transform:translateY(-3px);box-shadow:0 10px 30px #28a74566;background:linear-gradient(135deg,#218838,#1ea085)}.btn-next-question:active{transform:translateY(-1px)}.question-counter{font-size:.9rem;opacity:.9;font-weight:500}@media(max-width:768px){.practice-game{padding:15px}.game-header{flex-direction:column;gap:20px;text-align:center;padding:20px}.game-header h2{font-size:1.7rem}.score-display{font-size:1rem;padding:8px 16px}.question-card{padding:25px 20px}.question-text{font-size:1.2rem}.check-buttons{flex-direction:column;align-items:center}.btn-correct,.btn-incorrect{width:220px}.game-actions{flex-direction:column;align-items:center}.btn-primary,.btn-secondary{width:220px}.score-circle{width:120px;height:120px}.score-number{font-size:2rem}}@media(prefers-contrast:high){.game-header{background:#000;color:#fff;border:2px solid #fff}.question-card,.option-label{border:2px solid #000}.btn-submit,.btn-primary{background:#000;border:2px solid #fff}}.final-quiz{max-width:800px;margin:0 auto;padding:20px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#f8f9fa;min-height:100vh}.no-quiz{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a}.no-quiz h2{color:#495057;margin-bottom:30px;font-size:1.8rem;font-weight:600}.quiz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding:25px 30px;background:linear-gradient(135deg,#4a90e2,#6a5acd);border-radius:15px;color:#fff;box-shadow:0 6px 25px #4a90e24d}.quiz-header h2{margin:0;font-size:2rem;font-weight:700;color:#fff!important;text-shadow:0 2px 4px rgba(0,0,0,.3);letter-spacing:.5px}.quiz-progress{font-size:1.1rem;font-weight:600;background:#ffffff40;color:#fff!important;padding:10px 18px;border-radius:25px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);text-shadow:0 1px 2px rgba(0,0,0,.2)}.quiz-question-card{background:#fff;border-radius:15px;padding:35px;box-shadow:0 6px 30px #00000026;margin-bottom:25px;transition:all .3s ease;border:1px solid #e9ecef;color:#212529}.question-number{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px;color:#495057!important;font-weight:600;font-size:1rem}.question-type{background:linear-gradient(135deg,#e9ecef,#f8f9fa);padding:8px 16px;border-radius:20px;font-size:.9rem;color:#495057!important;font-weight:600;border:1px solid #dee2e6}.quiz-question{color:#212529!important;font-size:1.4rem;font-weight:600;margin-bottom:30px;line-height:1.6;text-align:left}.quiz-options{display:flex;flex-direction:column;gap:15px;margin-bottom:30px}.quiz-option{display:flex;align-items:center;padding:18px 20px;border:2px solid #e9ecef;border-radius:10px;cursor:pointer;transition:all .3s ease;background:#fafafa;text-align:left;width:100%;font-size:1.1rem}.quiz-option:hover{border-color:#4a90e2;background:#f0f7ff;transform:translateY(-1px);box-shadow:0 4px 15px #4a90e226}.quiz-option.selected{border-color:#4a90e2;background:#f0f7ff;box-shadow:0 4px 15px #4a90e233}.option-letter{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:#4a90e2;color:#fff;border-radius:50%;font-weight:700;margin-right:15px;font-size:.9rem;flex-shrink:0}.quiz-option.selected .option-letter{background:#2d5aa0;transform:scale(1.1)}.option-text{color:#495057;line-height:1.4}.quiz-option.selected .option-text{color:#4a90e2;font-weight:600}.quiz-short-answer{margin-bottom:30px}.quiz-textarea{width:100%;padding:18px 20px;border:2px solid #e9ecef;border-radius:10px;font-size:1.1rem;font-family:inherit;resize:vertical;transition:border-color .3s ease;background:#fafafa;color:#495057;line-height:1.5;min-height:120px}.quiz-textarea:focus{outline:none;border-color:#4a90e2;box-shadow:0 0 0 4px #4a90e21a;background:#fff}.quiz-textarea::placeholder{color:#6c757d;opacity:.8}.quiz-navigation{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:30px;padding-top:20px;border-top:2px dashed #dee2e6}.btn-quiz-nav{background:#fff;color:#495057;border:2px solid #dee2e6;padding:12px 24px;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000000d}.btn-quiz-nav:hover:not(:disabled){color:#212529;border-color:#adb5bd;background:#f8f9fa;transform:translateY(-2px);box-shadow:0 6px 20px #0000001a}.btn-quiz-nav:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-submit-quiz{background:linear-gradient(135deg,#28a745,#20c997);color:#fff;padding:15px 30px;border:none;border-radius:12px;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .3s ease;text-shadow:0 1px 2px rgba(0,0,0,.3);box-shadow:0 6px 20px #28a7454d;display:flex;align-items:center;justify-content:center;gap:8px}.btn-submit-quiz:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 10px 30px #28a74566;background:linear-gradient(135deg,#218838,#1ea085)}.btn-submit-quiz:disabled{opacity:.6;cursor:not-allowed;transform:none}.quiz-footer{text-align:center;margin-top:30px}.btn-back-small{background:#fff;color:#495057;border:2px solid #dee2e6;padding:10px 20px;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;font-weight:600;box-shadow:0 2px 8px #0000000d}.btn-back-small:hover{color:#212529;border-color:#adb5bd;background:#f8f9fa;transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.quiz-results{text-align:center;padding:45px;background:#fff;border-radius:20px;box-shadow:0 8px 40px #0000001f;border:1px solid #e9ecef}.quiz-results h2{color:#212529;font-size:2.5rem;margin-bottom:35px;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.1)}.results-circle{display:inline-flex;align-items:center;justify-content:center;width:140px;height:140px;border-radius:50%;background:linear-gradient(135deg,#4a90e2,#6a5acd);color:#fff;margin-bottom:25px;box-shadow:0 8px 30px #4a90e24d}.results-percentage{font-size:2.2rem;font-weight:800;text-shadow:0 2px 4px rgba(0,0,0,.3)}.results-score{color:#495057;font-size:1.3rem;margin:0 0 20px;font-weight:600}.results-message{color:#495057;font-size:1.2rem;font-style:italic;margin:25px 0;font-weight:500}.results-review{text-align:left;margin:40px 0;padding:25px;background:#f8f9fa;border-radius:15px;border:1px solid #e9ecef}.results-review h3{color:#212529;font-size:1.4rem;margin-bottom:25px;font-weight:700;text-align:center}.review-item{margin-bottom:25px;padding:20px;border-radius:10px;border-left:5px solid}.review-item.correct{background:linear-gradient(135deg,#e8f5e8,#f0fff0);border-left-color:#4caf50}.review-item.incorrect{background:linear-gradient(135deg,#ffeaea,#fff5f5);border-left-color:#f44336}.review-question{font-weight:700;color:#212529;margin-bottom:10px;font-size:1.1rem}.review-your-answer,.review-correct-answer{margin:8px 0;color:#495057;font-size:1rem;line-height:1.5}.review-your-answer strong,.review-correct-answer strong{color:#212529;font-weight:600}.results-actions{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.btn-primary,.btn-secondary{padding:15px 30px;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;text-shadow:0 1px 2px rgba(0,0,0,.2)}.btn-primary{background:linear-gradient(135deg,#4a90e2,#6a5acd);color:#fff;box-shadow:0 6px 20px #4a90e24d}.btn-primary:hover{transform:translateY(-3px);box-shadow:0 10px 30px #4a90e266}.btn-secondary{background:linear-gradient(135deg,#6c757d,#5a6268);color:#fff;box-shadow:0 6px 20px #6c757d4d}.btn-secondary:hover{background:linear-gradient(135deg,#5a6268,#495057);transform:translateY(-3px);box-shadow:0 10px 30px #6c757d66}@media(max-width:768px){.final-quiz{padding:15px}.quiz-header{flex-direction:column;gap:20px;text-align:center;padding:20px}.quiz-header h2{font-size:1.7rem}.quiz-progress{font-size:1rem;padding:8px 16px}.quiz-question-card{padding:25px 20px}.quiz-question{font-size:1.2rem}.quiz-navigation{flex-direction:column;gap:15px}.btn-quiz-nav,.btn-submit-quiz{width:100%}.results-actions{flex-direction:column;align-items:center}.btn-primary,.btn-secondary{width:220px}.results-circle{width:120px;height:120px}.results-percentage{font-size:2rem}.results-review{padding:20px}}@media(prefers-contrast:high){.quiz-header{background:#000;color:#fff;border:2px solid #fff}.quiz-question-card,.quiz-option{border:2px solid #000}.btn-submit-quiz,.btn-primary{background:#000;border:2px solid #fff}}.lesson-study{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:25px;max-width:1900px;margin:0 auto}.lesson-study.loading,.lesson-study.error{display:flex;align-items:center;justify-content:center}.loading-spinner{text-align:center;background:#fff;padding:50px;border-radius:20px;box-shadow:0 10px 30px #0003}.spinner{border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin:0 auto 25px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-box{background:#fff;padding:50px;border-radius:20px;box-shadow:0 10px 30px #0003;text-align:center;max-width:600px}.error-box h2{color:#ff6b6b;margin-bottom:20px;font-size:1.8rem}.study-header{background:#fff;padding:25px;border-radius:18px;box-shadow:0 6px 20px #0000001f;display:flex;align-items:center;gap:25px;max-width:1800px;margin-left:auto;margin-right:auto;margin-bottom:25px}.study-header h1{flex:1;margin:0;color:#333;font-size:32px;font-weight:700}.btn-back{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:12px;cursor:pointer;font-size:17px;font-weight:600;transition:all .3s ease}.btn-back:hover{background:#5a6268;transform:translateY(-3px);box-shadow:0 5px 15px #0003}.study-navigation{background:#fff;padding:20px;border-radius:18px;display:flex;gap:20px;justify-content:center;box-shadow:0 6px 20px #0000001f;max-width:1800px;margin-left:auto;margin-right:auto;margin-bottom:25px}.mode-btn{flex:1;max-width:220px;padding:18px 30px;border:3px solid #e9ecef;background:#fff;color:#333;border-radius:15px;font-size:19px;cursor:pointer;transition:all .3s ease;font-weight:600;min-height:60px;display:flex;align-items:center;justify-content:center}.mode-btn:hover{transform:translateY(-4px);box-shadow:0 8px 20px #00000040}.mode-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-color:#667eea;transform:translateY(-2px);box-shadow:0 6px 15px #667eea4d}.study-content{background:transparent;border-radius:0;padding:0;box-shadow:none;min-height:auto;max-width:1800px;margin:0 auto}.lesson-viewer{animation:fadeIn .5s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.lesson-header{margin-bottom:35px}.lesson-title{color:#333;font-size:32px;margin:0;display:flex;align-items:center;gap:18px;flex-wrap:wrap}.lesson-badge{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:10px 18px;border-radius:22px;font-size:15px;font-weight:600;box-shadow:0 3px 10px #f093fb4d}.section-content{margin-bottom:35px}.section-heading{color:#667eea;font-size:28px;margin-bottom:25px;padding-bottom:12px;border-bottom:4px solid #f0f0f0;font-weight:700}.section-body{line-height:1.8}.content-text{font-size:20px;color:#444;margin-bottom:30px;line-height:1.8}.image-references{background:#f8f9fa;padding:25px;border-radius:15px;margin:30px 0}.image-references h4{color:#667eea;margin-bottom:15px;font-size:1.2rem}.image-tags{display:flex;flex-wrap:wrap;gap:12px}.image-tag{background:#fff;padding:10px 18px;border-radius:10px;border:2px solid #667eea;color:#667eea;font-weight:600;font-size:15px}.vocabulary-box{background:linear-gradient(135deg,#ffecd2,#fcb69f);padding:30px;border-radius:18px;margin:30px 0;box-shadow:0 5px 15px #0000001a}.vocabulary-box h4{color:#333;margin-bottom:20px;font-size:1.3rem}.vocabulary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;margin-bottom:20px}.vocab-word{background:#fff;border:3px solid transparent;padding:15px 25px;border-radius:12px;cursor:pointer;font-size:17px;font-weight:600;transition:all .3s ease;color:#333;text-align:center}.vocab-word:hover{transform:scale(1.05);border-color:#ff6b6b;box-shadow:0 4px 12px #ff6b6b4d}.vocab-word.selected{background:#ff6b6b;color:#fff;transform:scale(1.1);box-shadow:0 6px 15px #ff6b6b66}.vocab-tooltip{background:#fff;padding:20px;border-radius:12px;text-align:center;font-size:17px;color:#333;animation:slideIn .3s ease;box-shadow:0 5px 15px #0000001a}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.section-progress{margin:35px 0}.progress-bar{background:#e9ecef;height:24px;border-radius:12px;overflow:hidden;margin-bottom:15px;box-shadow:inset 0 2px 4px #0000001a}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);height:100%;transition:width .5s ease;box-shadow:0 2px 8px #667eea4d}.progress-text{text-align:center;color:#666;font-weight:600;font-size:16px}.navigation-buttons{display:flex;gap:20px;justify-content:center;flex-wrap:wrap}.btn-nav,.btn-practice{padding:18px 35px;border:none;border-radius:15px;font-size:19px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:180px;min-height:55px}.btn-nav{background:#6c757d;color:#fff;flex:1;max-width:220px}.btn-nav:hover:not(:disabled){background:#5a6268;transform:translateY(-4px);box-shadow:0 8px 20px #00000040}.btn-nav:disabled{opacity:.5;cursor:not-allowed}.btn-practice{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;flex:1;max-width:280px}.btn-practice:hover{transform:translateY(-4px);box-shadow:0 10px 25px #f5576c80}.practice-game{animation:fadeIn .5s ease;background:#fff;border-radius:18px;padding:35px;box-shadow:0 6px 20px #0000001f}.game-header{text-align:center;margin-bottom:35px}.game-header h2{color:#667eea;font-size:36px;margin-bottom:15px;font-weight:700}.score-display{background:#f8f9fa;padding:12px 25px;border-radius:22px;display:inline-block;font-weight:600;color:#333;font-size:16px}.question-card{background:#fff;border:4px solid #e9ecef;border-radius:22px;padding:35px;margin-bottom:25px;transition:all .3s ease;box-shadow:0 4px 15px #00000014}.question-card.feedback-correct{border-color:#51cf66;background:linear-gradient(135deg,#d4fc79,#96e6a1);box-shadow:0 6px 20px #51cf664d}.question-card.feedback-incorrect{border-color:#ff6b6b;background:linear-gradient(135deg,#ffecd2,#fcb69f);box-shadow:0 6px 20px #ff6b6b4d}.question-number{background:#667eea;color:#fff;padding:10px 20px;border-radius:22px;display:inline-block;margin-bottom:20px;font-weight:600;font-size:15px}.question-text{color:#333;font-size:26px;margin-bottom:30px;line-height:1.5}.answer-input{display:flex;flex-direction:column;gap:18px}.answer-textarea{width:100%;padding:18px;border:3px solid #e9ecef;border-radius:15px;font-size:17px;font-family:inherit;resize:vertical;transition:border-color .3s ease;min-height:120px}.answer-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 10px #667eea33}.btn-submit{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:18px 35px;border-radius:15px;font-size:19px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:160px}.btn-submit:hover{transform:translateY(-4px);box-shadow:0 8px 20px #667eea80}.answer-reveal{display:flex;flex-direction:column;gap:25px}.your-answer,.correct-answer{background:#f8f9fa;padding:20px;border-radius:15px;box-shadow:0 2px 8px #0000000d}.your-answer h4,.correct-answer h4{color:#667eea;margin-bottom:12px;font-size:1.2rem}.self-check{text-align:center;padding:25px}.self-check p{font-size:20px;font-weight:600;margin-bottom:20px}.check-buttons{display:flex;gap:20px;justify-content:center}.btn-correct,.btn-incorrect{padding:18px 35px;border:none;border-radius:15px;font-size:19px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#fff;min-width:150px}.btn-correct{background:linear-gradient(135deg,#51cf66,#37b24d)}.btn-correct:hover{transform:translateY(-4px);box-shadow:0 8px 20px #51cf6680}.btn-incorrect{background:linear-gradient(135deg,#ff6b6b,#fa5252)}.btn-incorrect:hover{transform:translateY(-4px);box-shadow:0 8px 20px #ff6b6b80}.feedback-animation{text-align:center;padding:25px;font-size:26px;font-weight:600;border-radius:15px;margin-top:25px;animation:bounce .5s ease}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.correct-animation{background:#51cf6633;color:#37b24d}.incorrect-animation{background:#ff6b6b33;color:#fa5252}.game-complete{text-align:center;padding:50px}.game-complete h2{color:#667eea;font-size:40px;margin-bottom:35px;font-weight:700}.final-score{margin-bottom:35px}.score-circle{width:220px;height:220px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;align-items:center;justify-content:center;margin:0 auto 25px;box-shadow:0 12px 35px #667eea66}.score-number{color:#fff;font-size:60px;font-weight:700}.score-text{font-size:22px;color:#333;font-weight:600}.encouragement{font-size:26px;color:#667eea;margin:25px 0;font-weight:600}.game-actions{display:flex;gap:20px;justify-content:center;margin-top:35px}.no-questions{text-align:center;padding:70px 25px}.no-questions h2{color:#667eea;margin-bottom:25px;font-size:2rem}.game-footer{text-align:center;margin-top:25px}.btn-back-small{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:12px;font-size:15px;cursor:pointer;transition:all .3s ease;font-weight:600}.btn-back-small:hover{background:#5a6268;transform:translateY(-3px);box-shadow:0 4px 10px #0003}.final-quiz{animation:fadeIn .5s ease;background:#fff;border-radius:18px;padding:35px;box-shadow:0 6px 20px #0000001f}.quiz-header{text-align:center;margin-bottom:35px}.quiz-header h2{color:#667eea;font-size:36px;margin-bottom:15px;font-weight:700}.quiz-progress{background:#f8f9fa;padding:12px 25px;border-radius:22px;display:inline-block;font-weight:600;color:#333;font-size:16px}.quiz-question-card{background:#fff;border:4px solid #e9ecef;border-radius:22px;padding:35px;margin-bottom:25px;box-shadow:0 4px 15px #00000014}.quiz-question{color:#333;font-size:26px;margin-bottom:35px;padding-bottom:25px;border-bottom:4px solid #f0f0f0;line-height:1.5}.quiz-options{display:flex;flex-direction:column;gap:18px;margin-bottom:35px}.quiz-option{background:#fff;border:3px solid #e9ecef;padding:25px;border-radius:15px;display:flex;align-items:center;gap:18px;cursor:pointer;transition:all .3s ease;font-size:19px;text-align:left;box-shadow:0 2px 8px #0000000d}.quiz-option:hover{border-color:#667eea;transform:translate(8px);box-shadow:0 4px 12px #667eea33}.quiz-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;color:#fff;transform:translate(5px);box-shadow:0 6px 15px #667eea4d}.option-letter{background:#f8f9fa;width:45px;height:45px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0;font-size:18px}.quiz-option.selected .option-letter{background:#fff;color:#667eea}.option-text{flex:1}.quiz-short-answer{margin-bottom:35px}.quiz-textarea{width:100%;padding:18px;border:3px solid #e9ecef;border-radius:15px;font-size:17px;font-family:inherit;resize:vertical;transition:border-color .3s ease;min-height:120px}.quiz-textarea:focus{outline:none;border-color:#667eea;box-shadow:0 0 10px #667eea33}.quiz-navigation{display:flex;gap:20px;justify-content:center}.btn-quiz-nav,.btn-submit-quiz{padding:18px 35px;border:none;border-radius:15px;font-size:19px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#fff;min-width:160px}.btn-quiz-nav{background:#6c757d}.btn-quiz-nav:hover:not(:disabled){background:#5a6268;transform:translateY(-4px);box-shadow:0 8px 20px #00000040}.btn-quiz-nav:disabled{opacity:.5;cursor:not-allowed}.btn-submit-quiz{background:linear-gradient(135deg,#51cf66,#37b24d)}.btn-submit-quiz:hover:not(:disabled){transform:translateY(-4px);box-shadow:0 8px 20px #51cf6680}.btn-submit-quiz:disabled{opacity:.5;cursor:not-allowed}.quiz-footer{text-align:center;margin-top:25px}.quiz-results{text-align:center;padding:50px}.quiz-results h2{color:#667eea;font-size:40px;margin-bottom:35px;font-weight:700}.results-circle{width:220px;height:220px;border-radius:50%;background:linear-gradient(135deg,#51cf66,#37b24d);display:flex;align-items:center;justify-content:center;margin:0 auto 25px;box-shadow:0 12px 35px #51cf6666}.results-percentage{color:#fff;font-size:60px;font-weight:700}.results-score{font-size:22px;color:#333;font-weight:600;margin-bottom:25px}.results-message{font-size:26px;color:#667eea;margin:25px 0;font-weight:600}.results-review{max-width:900px;margin:45px auto;text-align:left}.results-review h3{color:#333;font-size:26px;margin-bottom:25px;text-align:center}.review-item{background:#f8f9fa;padding:25px;border-radius:15px;margin-bottom:18px;border-left:5px solid #e9ecef;box-shadow:0 2px 8px #0000000d}.review-item.correct{border-left-color:#51cf66;background:#51cf661a}.review-item.incorrect{border-left-color:#ff6b6b;background:#ff6b6b1a}.review-question{font-weight:600;margin-bottom:12px;color:#333;font-size:17px}.review-your-answer{margin-bottom:8px;color:#666;font-size:16px}.review-correct-answer{color:#667eea;font-weight:600;font-size:16px}.results-actions{display:flex;gap:20px;justify-content:center;margin-top:35px}.no-quiz{text-align:center;padding:70px 25px;background:#fff;border-radius:18px;box-shadow:0 6px 20px #0000001f}.no-quiz h2{color:#667eea;margin-bottom:25px;font-size:2rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:18px 35px;border-radius:15px;font-size:19px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:160px}.btn-primary:hover{transform:translateY(-4px);box-shadow:0 8px 20px #667eea80}.btn-secondary{background:#6c757d;color:#fff;border:none;padding:18px 35px;border-radius:15px;font-size:19px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:160px}.btn-secondary:hover{background:#5a6268;transform:translateY(-4px);box-shadow:0 8px 20px #00000040}@media(max-width:1700px){.lesson-study,.study-header,.study-navigation,.study-content{max-width:1500px}}@media(max-width:1500px){.lesson-study,.study-header,.study-navigation,.study-content{max-width:1300px}}@media(max-width:1200px){.lesson-study{max-width:100%;padding:20px}.study-header,.study-navigation,.study-content{max-width:100%}.study-header{padding:20px}.study-navigation{padding:15px}.mode-btn{padding:15px 25px;font-size:18px}}@media(max-width:768px){.study-navigation{flex-direction:column}.mode-btn{max-width:none}.navigation-buttons{flex-direction:column}.btn-nav,.btn-practice{max-width:none}.vocabulary-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.check-buttons,.game-actions,.results-actions{flex-direction:column}.lesson-title{font-size:26px}.section-heading{font-size:24px}.content-text{font-size:18px}.study-header h1{font-size:28px}.btn-back{padding:10px 20px;font-size:16px}}.app{min-height:100vh;background:#f5f7fa}
