body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}*,body{margin:0}*{box-sizing:border-box;padding:0}#root{min-height:100vh}.course-selector-container{background:linear-gradient(135deg,#1a1a2e,#16213e 50%,#0f3460);min-height:100vh;padding:2rem}.course-selector-container .container{margin:0 auto;max-width:1200px}.selector-header{margin-bottom:3rem;text-align:center}.selector-header h1{color:#fff;font-size:2.5rem;margin-bottom:.5rem}.selector-header .subtitle{color:#94a3b8;font-size:1.1rem}.courses-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:3rem}.course-card{align-items:center;background:#1e293b;border:2px solid #0000;border-radius:16px;cursor:pointer;display:flex;gap:1.5rem;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.course-card:before{background:#6366f1;background:var(--course-color,#6366f1);content:"";height:100%;left:0;position:absolute;top:0;width:4px}.course-card:hover{border-color:#6366f1;border-color:var(--course-color,#6366f1);box-shadow:0 10px 40px #0000004d;transform:translateY(-4px)}.course-icon{align-items:center;background:linear-gradient(135deg,#6366f1,#6366f180);background:linear-gradient(135deg,var(--course-color,#6366f1) 0,#6366f180 100%);border-radius:16px;display:flex;flex-shrink:0;font-size:2rem;height:70px;justify-content:center;width:70px}.course-info{flex:1 1;min-width:0}.course-info h2{color:#fff;font-size:1.4rem;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.course-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#94a3b8;display:-webkit-box;font-size:.9rem;margin-bottom:.75rem;overflow:hidden}.course-meta{display:flex;gap:1rem}.course-meta .meta-item{background:#6366f133;border-radius:20px;color:#a5b4fc;font-size:.8rem;padding:.25rem .75rem}.course-arrow{color:#6366f1;color:var(--course-color,#6366f1);font-size:1.5rem;opacity:.5;transition:all .3s ease}.course-card:hover .course-arrow{opacity:1;transform:translateX(4px)}.empty-state{padding:3rem}.empty-state h2{color:#fff;margin-bottom:.5rem}.empty-state p{color:#94a3b8}.motivation-section{margin-top:1rem;padding:2rem;text-align:center}.motivation-quote{color:#94a3b8;font-size:1.1rem;font-style:italic;line-height:1.6;margin:0 auto;max-width:600px}.quote-author{color:#64748b;display:block;font-size:.9rem;font-style:normal;margin-top:.75rem}.error-state{padding:3rem;text-align:center}.error-state h2{color:#f87171;margin-bottom:1rem}.error-state p{color:#94a3b8;margin-bottom:1.5rem}@media (max-width:768px){.course-selector-container{padding:1rem}.selector-header h1{font-size:1.8rem}.courses-grid{grid-template-columns:1fr}.course-card{padding:1.5rem}.course-icon{font-size:1.5rem;height:50px;width:50px}.course-info h2{font-size:1.2rem}.motivation-quote{font-size:1rem}}.home-container{min-height:100vh;padding:40px 20px}.home-header{color:#fff;margin-bottom:40px;text-align:center}.home-header h1{color:#fff;font-size:48px;margin-bottom:10px;text-shadow:2px 2px 4px #0003}.subtitle{font-size:20px;opacity:.9}.info-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:40px}.info-card{align-items:center;background:#fff;border-radius:12px;box-shadow:0 4px 6px #0000001a;display:flex;gap:16px;padding:24px;transition:transform .3s ease}.info-card:hover{box-shadow:0 8px 12px #00000026;transform:translateY(-4px)}.info-icon{font-size:48px}.info-content h3{color:#667eea;font-size:32px;margin:0 0 4px}.info-content p{color:#666;font-size:14px;margin:0}.main-actions{margin-bottom:30px}.action-buttons{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-top:30px}.action-btn{background:#1a1a2e;border-radius:12px;padding:30px;text-align:center;transition:all .3s ease}.action-btn:hover{background:#2d2d44;box-shadow:0 8px 20px #0000004d;transform:translateY(-4px)}.action-btn.secondary{background:#2d3748}.action-btn.secondary:hover{background:#4a5568}.action-icon{font-size:48px;margin-bottom:16px}.action-btn h3{color:#fff;font-size:18px;font-weight:600;margin-bottom:8px}.action-btn p{color:#a0aec0;font-size:14px;margin:0}.recent-exams{display:flex;flex-direction:column;gap:12px;margin-top:20px}.exam-item{align-items:center;background:#f8f9fa;border-radius:8px;display:flex;justify-content:space-between;padding:16px;transition:background .2s ease}.exam-item:hover{background:#e9ecef}.exam-info h4{color:#333;margin:0 0 4px}.exam-badge{border-radius:20px;font-size:14px;font-weight:600;padding:8px 16px}.exam-badge.passed{background:#d4edda;color:#155724}.exam-badge.failed{background:#f8d7da;color:#721c24}.footer-info{color:#fff;margin-top:40px;padding:20px;text-align:center}.footer-info p{font-size:18px;opacity:.9}@media (max-width:768px){.home-header h1{font-size:32px}.action-buttons,.info-grid{grid-template-columns:1fr}}.exam-config-container{align-items:center;display:flex;min-height:100vh;padding:40px 20px}.form-group label{font-weight:600}.form-control{border:2px solid #e0e0e0;border-radius:8px;font-size:16px;padding:12px;transition:border-color .3s ease;width:100%}.form-control:focus{border-color:#667eea;outline:none}.button-group{display:flex;gap:12px;margin-top:30px}.button-group button{flex:1 1}.preset-selector{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(3,1fr)}.preset-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:12px;cursor:pointer;display:flex;flex-direction:column;padding:20px 15px;transition:all .2s}.preset-btn:hover{border-color:#667eea;transform:translateY(-2px)}.preset-btn.active{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-color:#667eea}.exam-style-selector .preset-btn.active{border-width:2px}.exam-style-selector .preset-btn:first-child.active{background:linear-gradient(135deg,#e539351a,#e5393526);border-color:#e53935}.exam-style-selector .preset-btn:nth-child(2).active{background:linear-gradient(135deg,#43a0471a,#43a04726);border-color:#43a047}.preset-icon{font-size:2rem;margin-bottom:8px}.preset-name{color:#333;font-weight:600;margin-bottom:4px}.preset-desc{color:#666;font-size:.85rem;text-align:center}.preset-summary{background:#f8f9fa;border-radius:8px;margin-bottom:15px;padding:15px}.preset-summary p{color:#333;margin:0}.filter-section{background:#f8f9fa;border-radius:12px;margin-bottom:24px;padding:16px}.filter-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.filter-header label{align-items:center;display:flex;gap:8px;margin-bottom:0}.filter-hint{background:#667eea1a;border-radius:12px;color:#667eea;font-size:.85rem;font-weight:500;padding:4px 10px}.filter-actions{align-items:center;display:flex;gap:8px}.btn-link{background:none;border:none;color:#667eea;cursor:pointer;font-size:.9rem;padding:4px 8px;transition:color .2s}.btn-link:hover{color:#764ba2;text-decoration:underline}.separator{color:#ccc}.topic-filter-grid{display:flex;flex-direction:column;gap:12px}.fase-group{background:#fff;border:1px solid #e8e8e8;border-radius:10px;padding:12px}.fase-header{border-bottom:1px solid #f0f0f0;cursor:pointer;gap:10px;margin-bottom:10px;padding:4px 0 10px}.fase-header input[type=checkbox]{accent-color:#667eea;accent-color:var(--fase-color,#667eea);cursor:pointer;height:16px;width:16px}.fase-badge{border-radius:4px;color:#fff;font-size:.7rem;font-weight:700;min-width:28px;padding:3px 8px;text-align:center}.fase-title{color:#555;font-size:.85rem;font-weight:500}.fase-header.selected .fase-title{color:#333;font-weight:600}.topics-container{display:flex;flex-wrap:wrap;gap:8px}.topic-chip{align-items:center;background:#fafafa;border:1px solid #e0e0e0;border-radius:20px;cursor:pointer;display:inline-flex;font-size:.85rem;gap:6px;padding:6px 12px;transition:all .2s}.topic-chip:hover{background:#f5f5ff;border-color:#667eea}.topic-chip.selected{background:linear-gradient(135deg,#667eea26,#764ba226);border-color:#667eea}.topic-chip input[type=checkbox]{display:none}.chip-name{color:#444}.topic-chip.selected .chip-name{color:#333;font-weight:500}.chip-count{background:#e8e8e8;border-radius:10px;color:#888;font-size:.75rem;min-width:20px;padding:2px 6px;text-align:center}.topic-chip.selected .chip-count{background:#667eea;color:#fff}.topic-chip.disabled{cursor:not-allowed;opacity:.5}.topic-chip.disabled:hover{background:#fafafa;border-color:#e0e0e0}@media (max-width:768px){.exam-config-container{align-items:stretch;padding:20px 12px}.button-group{flex-direction:column}.fase-filter-grid,.preset-selector{grid-template-columns:1fr}}.exam-page-container{min-height:100vh;padding:20px}.exam-header{margin-bottom:20px}.exam-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.exam-timer{color:#333;display:flex;font-weight:600;justify-content:flex-end;margin-bottom:12px}.exam-info h2{margin:0}.exam-info p{color:#666;font-size:14px;margin:0}.progress-bar{width:100%}.progress-fill{background:linear-gradient(135deg,#667eea,#764ba2)}.question-card,.question-header{margin-bottom:20px}.question-header{display:flex;justify-content:space-between}.question-number{background:#667eea;border-radius:4px;color:#fff;font-weight:600;padding:6px 12px}.question-category{background:#f0f0f0;color:#666}.flag-btn,.question-category{border-radius:4px;padding:6px 12px}.flag-btn{background:#fff;border:2px solid #e0e0e0;cursor:pointer;font-size:14px;transition:all .2s}.flag-btn:hover{background:#fff8e1;border-color:#ff9800}.flag-btn.flagged{background:#ff9800;border-color:#ff9800;color:#fff}.question-text{font-size:20px;line-height:1.6;margin-bottom:12px;white-space:pre-line}.question-note{background:#fff3cd;border-left:4px solid #ffc107;border-radius:4px;color:#856404;margin-bottom:20px;padding:12px}.ai-panel{margin-top:16px}.ai-panel-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:12px}.ai-panel-title{color:#0b0f19;font-weight:700;letter-spacing:.3px}.btn-ai{background:linear-gradient(135deg,#0ea5e9,#6366f1);border:none;box-shadow:0 8px 18px #0ea5e940;font-weight:700}.btn-ai:hover:not(:disabled){box-shadow:0 12px 22px #6366f159;transform:translateY(-1px)}.btn-ai:disabled{cursor:not-allowed;opacity:.6}.ai-result{background:#f3f6ff;border:1px solid #dbe3ff;border-radius:6px;padding:12px}.ai-title{color:#2c3e50;font-weight:600;margin-bottom:6px}.ai-suggestion{color:#1f2a44;font-size:16px;font-weight:700;margin-bottom:8px}.ai-suggestion-llm{color:#475569;font-size:14px;font-weight:600;margin-top:-4px}.ai-explanation{color:#2c3e50;font-size:14px;line-height:1.5;margin-bottom:10px}.ai-ranked{color:#555;font-size:13px}.ai-ranked-item{margin-bottom:4px}.ai-error{color:#b00020;font-size:13px}.ai-ask{border-top:1px solid #e2e8f0;margin-top:16px;padding-top:12px}.ai-ask-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:10px}.btn-ai-secondary{background:#0f172a;border:none;color:#fff;font-weight:600}.btn-ai-secondary:hover:not(:disabled){box-shadow:0 10px 18px #0f172a40;transform:translateY(-1px)}.btn-ai-secondary:disabled{cursor:not-allowed;opacity:.6}.ai-ask-input{background:#fff;border:1px solid #d0d7e2;border-radius:6px;font-family:inherit;font-size:14px;padding:10px 12px;resize:vertical;width:100%}.ai-ask-result{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:10px;padding:10px 12px}.ai-ask-response{color:#1f2937;font-size:14px;line-height:1.6}.ai-ask-response code{background:#f1f5f9;border-radius:3px;color:#e53e3e;font-family:Monaco,Courier New,monospace;font-size:13px;padding:2px 6px}.ai-ask-response pre{background:#1e1e1e!important;border:1px solid #334155;border-radius:8px;margin:12px 0!important;overflow-x:auto;padding:16px!important}.ai-ask-response pre code{background:#0000!important;color:inherit!important;font-size:13px;line-height:1.5;padding:0!important}.ai-ask-response strong{color:#0f172a;font-weight:600}.ai-ask-response blockquote,.ai-ask-response em{color:#475569;font-style:italic}.ai-ask-response blockquote{border-left:4px solid #667eea;margin:12px 0;padding-left:16px}.ai-ask-response hr{border:none;border-top:1px solid #e2e8f0;margin:16px 0}.ai-ask-response a{color:#667eea;text-decoration:none}.ai-ask-response a:hover{text-decoration:underline}.ai-ask-sources{border-top:1px solid #e2e8f0;color:#475569;font-size:12px;margin-top:12px;padding-top:12px}.ai-ask-source{background:#f8fafc;border-left:3px solid #667eea;border-radius:4px;margin-bottom:6px;padding:4px 8px}.options{display:flex;flex-direction:column;gap:12px}.jump-group{align-items:center;display:flex;gap:10px}.jump-input{border:1px solid #ddd;border-radius:6px;font-size:14px;padding:10px 12px;width:120px}.jump-input:focus{border-color:#667eea;box-shadow:0 0 0 2px #667eea33;outline:none}.option{align-items:center;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;padding:16px;transition:all .2s ease}.option:hover{background:#f8f9fa;border-color:#667eea}.option.selected{background:#e7f0ff;border-color:#667eea}.option-letter{background:#667eea;flex-shrink:0;font-weight:600;margin-right:12px}.option.selected .option-letter{background:#28a745}.option-text{flex:1 1;line-height:1.5}.navigation{display:flex;gap:12px;justify-content:space-between}.navigation button{flex:1 1;max-width:200px}@media (max-width:768px){.exam-info{align-items:flex-start;flex-direction:column;gap:6px}.exam-timer{justify-content:flex-start;margin-bottom:8px}.question-header{align-items:flex-start;flex-direction:column;gap:10px}.question-text{font-size:18px}.jump-group{align-items:stretch;flex-direction:column}.jump-input{width:100%}.navigation{align-items:stretch;flex-direction:column}.navigation button{max-width:none}.ai-panel-header{align-items:flex-start;flex-direction:column}}.option.correct{background-color:#d4edda!important;border-color:#28a745!important}.option.wrong{background-color:#f8d7da!important;border-color:#dc3545!important}.feedback-icon{font-size:24px;font-weight:700;margin-left:auto}.option.correct .feedback-icon{color:#28a745}.option.wrong .feedback-icon{color:#dc3545}.immediate-feedback{margin-top:24px}.feedback-box{border:2px solid;border-radius:8px;padding:20px}.feedback-box.correct{background:#d4edda;border-color:#28a745}.feedback-box.incorrect{background:#f8d7da;border-color:#dc3545}.feedback-header{font-size:20px;font-weight:700;margin-bottom:12px}.feedback-box.correct .feedback-header{color:#155724}.feedback-box.incorrect .feedback-header{color:#721c24}.feedback-correct-answer{background:#ffffff80;border-radius:4px;margin:12px 0;padding:12px}.feedback-explanation{background:#e7f3ff;border-left:4px solid #007bff;border-radius:4px;margin-top:16px;padding:16px}.feedback-explanation strong{color:#007bff;display:block;margin-bottom:8px}.feedback-explanation p{color:#333;line-height:1.6;margin:0}.btn-warning{background:#ffc107;color:#000;font-weight:600}.btn-warning:hover:not(:disabled){background:#e0a800}.btn-warning:disabled{background:#f0f0f0;color:#999;cursor:not-allowed}.btn-danger{font-weight:600}.btn-danger:hover:not(:disabled){background:#c82333}.results-container{min-height:100vh;padding:40px 20px}.results-header{padding:40px;text-align:center}.results-header.passed{background:linear-gradient(135deg,#d4edda,#c3e6cb);border:2px solid #28a745}.results-header.failed{background:linear-gradient(135deg,#f8d7da,#f5c6cb);border:2px solid #dc3545}.result-icon{font-size:80px;margin-bottom:20px}.results-header h1{font-size:36px;margin-bottom:12px}.result-message{color:#666;font-size:18px}.score-card{align-items:center;display:flex;flex-wrap:wrap;gap:40px;justify-content:space-around;padding:40px}.score-circle{height:200px;position:relative;width:200px}.score-text{left:50%;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.score-text h2{color:#333;font-size:48px;margin:0}.score-text p{color:#666;margin:0}.score-details{display:flex;flex-direction:column;gap:16px}.detail-item{align-items:center;border-bottom:1px solid #e0e0e0;display:flex;justify-content:space-between;min-width:300px;padding:12px 0}.detail-label{color:#666}.detail-value{color:#333;font-weight:600}.detail-badge{border-radius:4px;font-weight:600;padding:6px 12px}.detail-badge.passed{background:#d4edda;color:#155724}.detail-badge.failed{background:#f8d7da;color:#721c24}.review-section{margin-top:30px}.questions-review{display:flex;flex-direction:column;gap:16px;margin-top:20px}.review-item{border-left:4px solid;border-radius:8px;padding:20px}.review-item.correct{background:#d4edda;border-color:#28a745}.review-item.incorrect{background:#f8d7da;border-color:#dc3545}.review-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.review-number{color:#333;font-weight:600}.review-status{border-radius:4px;font-weight:600;padding:4px 8px}.review-status.correct{color:#155724}.review-status.incorrect{color:#721c24}.review-question{font-weight:500;margin-bottom:12px}.review-answers{display:flex;flex-direction:column;font-size:14px;gap:8px;margin-top:12px}.review-explanation{background:#fff;font-size:14px;margin-top:12px;padding:12px}.results-actions{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;margin-top:40px}@media (max-width:768px){.score-card{flex-direction:column}.detail-item{min-width:auto}.results-actions{flex-direction:column}.results-actions button{width:100%}}.review-note{background:#fff3cd;border-left:4px solid #ffc107;font-size:14px;margin:16px 0;padding:12px}.review-all-options{display:flex;flex-direction:column;gap:12px;margin:20px 0}.review-option{background:#f8f9fa;border:2px solid #e0e0e0;border-radius:8px;padding:16px;transition:all .3s ease}.review-option.option-correct{background:#d4edda;border-color:#28a745}.review-option.option-wrong{background:#f8d7da;border-color:#dc3545}.option-header{gap:12px;margin-bottom:8px}.option-header,.option-letter{align-items:center;display:flex}.option-letter{background:#007bff;border-radius:50%;color:#fff;font-size:16px;font-weight:700;height:32px;justify-content:center;width:32px}.review-option.option-correct .option-letter{background:#28a745}.review-option.option-wrong .option-letter{background:#dc3545}.option-badge{border-radius:12px;font-size:12px;font-weight:600;padding:4px 12px}.option-badge.correct{background:#28a745;color:#fff}.option-badge.wrong{background:#dc3545;color:#fff}.option-badge.correct-choice{background:#17a2b8;color:#fff}.option-text{color:#333;line-height:1.6;margin:0;padding-left:44px}.review-explanation{background:#e7f3ff;border-left:4px solid #007bff;border-radius:4px;margin-top:20px;padding:16px}.review-explanation p{color:#333;line-height:1.6;margin:8px 0 0}.review-explanation strong{color:#007bff;display:block;margin-bottom:8px}.review-item.flagged{border-right:4px solid #ff9800}.flagged-badge{border-radius:4px;font-size:12px;font-weight:600;padding:4px 10px}.btn-warning,.flagged-badge{background:#ff9800;color:#fff}.btn-warning:hover{background:#f57c00}.study-home-container{min-height:100vh;padding:20px 0}.study-header{align-items:center;background:#ffffff1a;border-radius:12px;display:flex;justify-content:space-between;margin-bottom:30px;padding:20px}.header-center{text-align:center}.study-header h1{color:#fff;margin-bottom:5px}.study-header .subtitle{color:#fffc;margin:0}.study-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:30px}.stat-card{align-items:center;background:#fff;border:1px solid #0000000d;border-radius:12px;box-shadow:0 2px 12px #00000014;display:flex;gap:16px;padding:20px 24px}.stat-card.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.stat-card.clickable:hover{box-shadow:0 6px 20px #00000026;transform:translateY(-3px)}.stat-icon{color:#667eea;font-size:2.5rem;font-weight:700;min-width:60px;text-align:center}.stat-content h3{color:#333;font-size:1rem;font-weight:600;letter-spacing:.5px;margin:0;text-transform:uppercase}.stat-content p{color:#888;font-size:.8rem;font-weight:400;margin:0}.fase-filter{margin-bottom:30px}.fase-filter h2{margin-bottom:15px}.fase-buttons{display:flex;flex-wrap:wrap;gap:10px}.fase-btn{align-items:center;background:#f8f9fa;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;display:flex;flex-direction:column;min-width:100px;padding:12px 20px;transition:all .2s}.fase-btn:hover{box-shadow:0 2px 10px #0000001a}.fase-btn.active,.fase-btn:hover{background:#fff;border-color:#667eea;border-color:var(--fase-color,#667eea)}.fase-btn.active{box-shadow:0 4px 15px #00000026}.fase-num{color:#333;font-size:.95rem;font-weight:600}.fase-count{color:#888;font-size:.75rem;font-weight:400}.fases-list{display:flex;flex-direction:column;gap:25px}.fase-section{padding:20px}.fase-header{align-items:center;border-left:4px solid #667eea;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:15px;padding-left:15px}.fase-title h2{color:#333;margin:0}.fase-subtitle{color:#666;font-size:.9rem}.fase-stats{color:#888;display:flex;font-size:.9rem;gap:20px}.quick-actions{margin-bottom:30px}.actions-grid{display:flex;flex-wrap:wrap;gap:15px}.action-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:10px;padding:15px 25px;transition:transform .2s,box-shadow .2s}.action-btn:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.action-icon{font-size:1.2rem}.topics-section h2{margin-bottom:20px}.topics-list{display:flex;flex-direction:column;gap:15px}.topic-card{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:20px;padding:20px;transition:all .2s}.topic-card:hover{background:#fff;border-color:#667eea;box-shadow:0 4px 15px #0000001a}.topic-order{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-weight:700;height:40px;justify-content:center;width:40px}.topic-info{flex:1 1}.topic-info h3{color:#333;margin:0 0 5px}.topic-info p{color:#666;font-size:.9rem;margin:0 0 10px}.topic-meta{display:flex;flex-wrap:wrap;gap:15px}.meta-item{color:#888;font-size:.85rem}.meta-item.has-artifact,.meta-item.has-pdf{color:#28a745}.topic-arrow{color:#667eea;font-size:1.5rem}.form-group input,.form-group select,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:12px;transition:border-color .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.modal-actions{margin-top:20px}@media (max-width:768px){.study-header{flex-direction:column;gap:15px}.study-stats{grid-template-columns:1fr}.topic-card{flex-wrap:wrap}}.ai-modal-overlay{animation:fadeIn .2s ease;background:#000000b3;bottom:0;display:flex;justify-content:flex-end;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.ai-modal{animation:slideIn .3s ease;background:#fff;display:flex;flex-direction:column;height:100%;max-width:100%;width:500px}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.ai-modal-header{align-items:center;background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;display:flex;justify-content:space-between;padding:20px}.ai-modal-header h2{color:#fff;font-size:1.3rem;margin:0}.close-btn{background:none;border:none;color:#fff;cursor:pointer;font-size:2rem;line-height:1;opacity:.8;padding:0;transition:opacity .2s}.close-btn:hover{opacity:1}.ai-status-warning{align-items:center;background:#fff3cd;color:#856404;display:flex;flex-wrap:wrap;gap:10px;padding:15px 20px}.warning-icon{font-size:1.2rem}.config-hint{color:#6c757d;font-size:.85rem;margin-top:5px;width:100%}.ai-mode-selector{border-bottom:1px solid #eee;display:flex;gap:10px;overflow-x:auto;padding:15px}.mode-btn{align-items:center;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;min-width:80px;padding:10px 15px;transition:all .2s}.mode-btn.active,.mode-btn:hover{border-color:#11998e}.mode-btn.active{background:linear-gradient(135deg,#11998e1a,#38ef7d1a)}.mode-icon{font-size:1.3rem;margin-bottom:4px}.mode-name{color:#666;font-size:.75rem;text-align:center}.mode-btn.active .mode-name{color:#11998e;font-weight:500}.ai-content-input{display:flex;flex:1 1;flex-direction:column;padding:20px}.ai-content-input label{color:#333;font-weight:500;margin-bottom:10px}.ai-content-input textarea{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-family:inherit;font-size:1rem;min-height:200px;padding:15px;resize:none}.ai-content-input textarea:focus{border-color:#11998e;outline:none}.start-btn{background:linear-gradient(135deg,#11998e,#38ef7d);margin-top:15px}.ai-messages{display:flex;flex:1 1;flex-direction:column;gap:15px;overflow-y:auto;padding:20px}.message{animation:messageIn .2s ease;max-width:90%}@keyframes messageIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end}.message.assistant{align-self:flex-start}.message-header{color:#888;font-size:.8rem;margin-bottom:5px}.message-content{border-radius:12px;line-height:1.6;padding:15px}.message.user .message-content{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom-right-radius:4px;color:#fff}.message.assistant .message-content{background:#f4f4f4;border-bottom-left-radius:4px;color:#333}.message-content p{margin:0 0 10px}.message-content p:last-child{margin-bottom:0}.message-content ol,.message-content ul{margin:10px 0;padding-left:20px}.message-content code{background:#0000001a;border-radius:4px;font-family:monospace;font-size:.9em;padding:2px 6px}.message.user .message-content code{background:#fff3}.message-content pre{border-radius:8px;margin:10px 0;overflow:hidden}.ai-error{background:#f8d7da;border-radius:8px;color:#721c24;font-size:.9rem;margin:0 20px;padding:12px 20px}.ai-input-area{background:#fafafa;border-top:1px solid #eee;display:flex;gap:10px;padding:15px 20px}.ai-input-area textarea{border:2px solid #e0e0e0;border-radius:8px;flex:1 1;font-family:inherit;font-size:1rem;padding:12px;resize:none}.ai-input-area textarea:focus{border-color:#11998e;outline:none}.send-btn{background:linear-gradient(135deg,#11998e,#38ef7d);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1.2rem;padding:12px 20px;transition:transform .2s}.send-btn:hover:not(:disabled){transform:scale(1.05)}.send-btn:disabled{cursor:not-allowed;opacity:.5}.ai-modal-footer{background:#f8f9fa;border-top:1px solid #eee;color:#888;display:flex;font-size:.8rem;justify-content:space-between;padding:10px 20px}.context-info,.provider-info{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:600px){.ai-modal{width:100%}.ai-mode-selector{gap:8px;padding:10px}.mode-btn{min-width:70px;padding:8px 12px}.mode-icon{font-size:1.1rem}.mode-name{font-size:.7rem}}.flashcard-container{padding:20px}.flashcard-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:24px}.flashcard-header,.flashcard-progress{align-items:center;display:flex;gap:12px}.flashcard-progress{flex:1 1;min-width:200px}.progress-bar{background:#e0e0e0;border-radius:4px;flex:1 1;height:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;height:100%;transition:width .3s ease}.progress-text{color:#555;font-size:.95rem;font-weight:600;white-space:nowrap}.flashcard-stats{display:flex;gap:16px}.stat-mastered{color:#28a745;font-size:.9rem;font-weight:500}.flashcard-wrapper{cursor:pointer;margin-bottom:24px;perspective:1000px}.flashcard{min-height:280px;position:relative;transform-style:preserve-3d;transition:transform .6s cubic-bezier(.4,0,.2,1);width:100%}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-face{align-items:center;-webkit-backface-visibility:hidden;backface-visibility:hidden;border-radius:16px;bottom:0;box-shadow:0 10px 40px #00000026;display:flex;flex-direction:column;justify-content:center;left:0;min-height:280px;padding:32px;position:absolute;right:0;text-align:center;top:0}.flashcard-front{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.flashcard-back{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;transform:rotateY(180deg)}.flashcard.mastered .flashcard-back,.flashcard.mastered .flashcard-front{box-shadow:0 0 0 4px gold,0 10px 40px #00000026}.card-label{font-size:.75rem;font-weight:600;letter-spacing:2px;margin-bottom:16px;opacity:.8;text-transform:uppercase}.card-content{font-size:1.3rem;font-weight:500;line-height:1.6;max-width:90%}.card-hint{bottom:16px;font-size:.8rem;opacity:.6;position:absolute}.flashcard-controls{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between}.fc-btn{border:none;border-radius:8px;cursor:pointer;font-size:.95rem;font-weight:500;padding:12px 20px;transition:all .2s ease}.fc-btn:disabled{cursor:not-allowed;opacity:.4}.fc-btn-nav{background:#f0f0f0;color:#333}.fc-btn-nav:hover:not(:disabled){background:#e0e0e0}.fc-btn-group{display:flex;gap:8px}.fc-btn-mastered{background:#fff;border:2px solid #28a745;color:#28a745}.fc-btn-mastered:hover{background:#f0fff4}.fc-btn-mastered.active{background:#28a745;color:#fff}.fc-btn-shuffle{background:#fff;border:2px solid #667eea;color:#667eea}.fc-btn-shuffle:hover{background:#f0f4ff}.fc-btn-reset{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;margin-left:12px}.fc-btn-reset:hover{box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.flashcard-shortcuts{color:#888;font-size:.85rem;margin-top:20px;text-align:center}.flashcard-shortcuts kbd{background:#f0f0f0;border:1px solid #ddd;border-radius:4px;font-family:inherit;font-size:.8rem;margin:0 2px;padding:2px 8px}.flashcard-complete{align-items:center;background:linear-gradient(135deg,#ffecd2,#fcb69f);border-radius:12px;display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:24px;padding:16px 24px}.complete-icon{font-size:1.5rem}.flashcard-empty{color:#666;padding:60px 20px;text-align:center}.empty-icon{margin-bottom:16px;opacity:.5}.flashcard-empty p{font-size:1.1rem;margin-bottom:8px}.empty-hint{color:#999;font-size:.9rem}@media (max-width:600px){.flashcard-face{min-height:240px;padding:24px 16px}.card-content{font-size:1.1rem}.flashcard-controls{flex-direction:column}.fc-btn-group{justify-content:center;order:-1;width:100%}.fc-btn-nav{flex:1 1}}.flashcard-wrapper:hover .flashcard:not(.flipped){transform:rotateY(5deg)}.flashcard-wrapper:active .flashcard{transform:scale(.98)}.flashcard.flipped .flashcard-wrapper:hover{transform:rotateY(185deg)}.topic-view-container{min-height:100vh;padding:20px 0}.header-nav,.topic-header{margin-bottom:20px}.topic-header h1{color:#333;margin-bottom:10px}.topic-description{color:#666;font-size:1.1rem;margin-bottom:20px}.pdf-section{border-top:1px solid #eee;margin-top:20px;padding-top:20px}.pdf-actions{display:flex;flex-wrap:wrap;gap:10px}.lessons-section{border-radius:0 12px 12px 12px}.section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.section-header h2{margin:0}.lessons-list{display:flex;flex-direction:column;gap:15px}.lesson-card{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:20px;padding:20px;transition:all .2s}.lesson-card:hover{background:#fff;border-color:#667eea;box-shadow:0 4px 15px #0000001a}.lesson-order{align-items:center;background:#667eea;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.9rem;font-weight:700;height:36px;justify-content:center;width:36px}.lesson-info{flex:1 1}.lesson-info h3{color:#333;font-size:1.1rem;margin:0 0 5px}.lesson-info p{color:#666;font-size:.9rem;margin:0 0 10px}.lesson-meta{display:flex;flex-wrap:wrap;gap:10px}.meta-tag{background:#e8f4fd;border-radius:4px;color:#1976d2;font-size:.8rem;padding:4px 10px}.lesson-arrow{color:#667eea;font-size:1.3rem}.artifacts-section{display:flex;flex-direction:column;gap:20px}.artifact-card{border-radius:12px}.artifact-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:15px}.artifact-header h3{color:#333;margin:0}.artifact-actions{display:flex;gap:10px}.artifact-content{background:#f8f9fa;border-radius:8px;line-height:1.6;min-height:100px;padding:20px}.artifact-content .placeholder{color:#999;font-style:italic}.artifact-content.markdown-content{white-space:normal}.artifact-content.markdown-content h1{border-bottom:2px solid #667eea;color:#333;font-size:1.5rem;margin:0 0 16px;padding-bottom:8px}.artifact-content.markdown-content h2{border-bottom:1px solid #e0e0e0;color:#444;font-size:1.25rem;margin:24px 0 12px;padding-bottom:6px}.artifact-content.markdown-content h3{color:#555;font-size:1.1rem;margin:20px 0 10px}.artifact-content.markdown-content p{color:#444;margin:0 0 12px}.artifact-content.markdown-content ol,.artifact-content.markdown-content ul{margin:0 0 16px;padding-left:24px}.artifact-content.markdown-content li{color:#444;margin-bottom:8px}.artifact-content.markdown-content li::marker{color:#667eea}.artifact-content.markdown-content strong{color:#333;font-weight:600}.artifact-content.markdown-content em{color:#666}.artifact-content.markdown-content code{background:#e8e8e8;border-radius:4px;color:#d63384;font-family:Monaco,Menlo,monospace;font-size:.9em;padding:2px 6px}.artifact-content.markdown-content pre{background:#2d2d2d;border-radius:8px;margin:16px 0;overflow-x:auto;padding:16px}.artifact-content.markdown-content pre code{background:none;color:#f8f8f2;font-size:.85rem;padding:0}.artifact-content.markdown-content blockquote{background:#f0f0f0;border-left:4px solid #667eea;border-radius:0 8px 8px 0;margin:16px 0;padding:12px 20px}.artifact-content.markdown-content blockquote p{color:#555;margin:0}.artifact-content.markdown-content hr{border:none;border-top:1px solid #e0e0e0;margin:24px 0}.artifact-content.markdown-content a{color:#667eea;text-decoration:none}.artifact-content.markdown-content a:hover{text-decoration:underline}.artifact-card textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;line-height:1.6;padding:15px;resize:vertical;width:100%}.artifact-card textarea:focus{border-color:#667eea;outline:none}.empty-state{color:#666;padding:40px}.modal-overlay{align-items:center;background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.modal-content h2{color:#333}.form-group,.modal-content h2{margin-bottom:20px}.form-group label{color:#333;display:block;font-weight:500;margin-bottom:8px}.form-group input,.form-group textarea{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;padding:12px;width:100%}.form-group input:focus,.form-group textarea:focus{border-color:#667eea;outline:none}.modal-actions{display:flex;gap:10px;justify-content:flex-end}@media (max-width:768px){.header-nav,.tabs{flex-wrap:wrap}.artifact-header{align-items:flex-start;flex-direction:column}.lesson-card{flex-wrap:wrap}}.lesson-view-container{min-height:100vh;padding:20px 0}.lesson-header{margin-bottom:20px}.header-nav{align-items:center;flex-wrap:wrap;justify-content:space-between;margin-bottom:15px}.header-actions,.header-nav{display:flex;gap:10px}.lesson-breadcrumb{color:#666;font-size:.9rem;margin-bottom:10px}.lesson-breadcrumb .separator{color:#999;margin:0 8px}.lesson-breadcrumb .current{color:#667eea;font-weight:500}.lesson-header h1{color:#333;margin-bottom:10px}.lesson-description{color:#666;margin-bottom:15px}.lesson-duration{color:#888;font-size:.9rem}.tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.tab{background:#fffc;border:none;border-radius:8px 8px 0 0;color:#666;cursor:pointer;font-size:1rem;font-weight:500;padding:12px 24px;transition:all .2s}.tab:hover{background:#fff;color:#333}.tab.active{background:#fff;box-shadow:0 -2px 10px #0000001a;color:#667eea}.lesson-content{border-radius:0 12px 12px 12px;min-height:400px}.content-section{padding:10px}.content-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:20px}.content-header h2{color:#333;margin:0}.content-actions{display:flex;flex-wrap:wrap;gap:10px}.markdown-content{color:#333;line-height:1.8}.markdown-content h1,.markdown-content h2,.markdown-content h3{margin-bottom:.5em;margin-top:1.5em}.markdown-content p{margin-bottom:1em}.markdown-content ol,.markdown-content ul{margin-bottom:1em;padding-left:2em}.markdown-content li{margin-bottom:.5em}.markdown-content code{background:#f4f4f4;border-radius:4px;font-family:Monaco,Consolas,monospace;font-size:.9em;padding:2px 6px}.markdown-content pre{border-radius:8px;margin:1em 0;overflow:hidden}.transcription-content{color:#333;font-size:1rem;line-height:1.8;white-space:pre-wrap}.pdf-section .pdf-embed{border:1px solid #e0e0e0;border-radius:8px;margin-top:15px;overflow:hidden}.pdf-embed iframe{border:none}.empty-content{color:#666;padding:60px 20px;text-align:center}.empty-content p{margin-bottom:20px}.content-section textarea{border:2px solid #e0e0e0;border-radius:8px;font-family:inherit;font-size:1rem;line-height:1.6;padding:15px;resize:vertical;width:100%}.content-section textarea:focus{border-color:#667eea;outline:none}.lesson-navigation{margin-top:30px}.nav-buttons{display:flex;gap:15px;justify-content:space-between}.nav-buttons .btn{flex:0 1 auto;max-width:45%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-ai:hover{box-shadow:0 4px 15px #11998e66}.btn-small{font-size:.9rem;padding:8px 16px}@media (max-width:768px){.header-nav{align-items:stretch;flex-direction:column}.header-actions{justify-content:flex-end}.content-header{align-items:flex-start}.content-header,.nav-buttons{flex-direction:column}.nav-buttons .btn{max-width:100%}}.error-notebook-container{min-height:100vh;padding:20px 0}.error-header{margin-bottom:20px;text-align:center}.error-header .header-nav{display:flex;justify-content:flex-start;margin-bottom:20px}.error-header h1{color:#333;margin-bottom:10px}.error-header .subtitle{color:#666;margin-bottom:20px}.error-stats{border-top:1px solid #eee;display:flex;gap:40px;justify-content:center;padding-top:20px}.stat{text-align:center}.stat-value{color:#667eea;display:block;font-size:2rem;font-weight:700}.stat-label{color:#666;font-size:.9rem}.filters{display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px}.filter-group{align-items:center;display:flex;gap:10px}.filter-group label{color:#333;font-weight:500}.filter-group select{border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;min-width:200px;padding:10px 15px}.filter-group select:focus{border-color:#667eea;outline:none}.empty-state{padding:60px 20px;text-align:center}.empty-icon{font-size:4rem;margin-bottom:20px}.empty-state h3{color:#333;margin-bottom:10px}.empty-state p{color:#666;margin-bottom:20px}.errors-list{display:flex;flex-direction:column;gap:20px}.error-card{border-left:4px solid #dc3545;transition:all .2s}.error-card.reviewed{border-left-color:#28a745;opacity:.8}.error-card:hover{box-shadow:0 6px 20px #00000026}.error-card-header{align-items:center;display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between;margin-bottom:15px}.error-meta{display:flex;flex-wrap:wrap;gap:15px}.times-wrong{background:#dc3545;border-radius:4px;color:#fff;font-size:.85rem;font-weight:500;padding:4px 10px}.last-wrong{color:#888;font-size:.85rem}.reviewed-badge{background:#28a745;border-radius:4px;color:#fff;font-size:.85rem;padding:4px 10px}.error-question{margin-bottom:15px}.error-question h3{color:#888;font-size:.9rem;margin-bottom:8px}.error-question p{color:#333;line-height:1.6}.error-answers{grid-gap:15px;display:grid;gap:15px;grid-template-columns:1fr 1fr;margin-bottom:15px}.answer{border-radius:8px;padding:15px}.answer.wrong{background:#f8d7da;color:#721c24}.answer.correct{background:#d4edda;color:#155724}.error-analysis{background:#f8f9fa;border-radius:8px;margin-bottom:15px;padding:15px}.error-analysis.editing{background:#fff;border:2px solid #667eea}.analysis-item{line-height:1.6;margin-bottom:10px}.analysis-item:last-child{margin-bottom:0}.analysis-item.rule{background:#fff3cd;border-radius:4px;color:#856404;padding:10px}.analysis-item.variation{color:#666;font-style:italic}.analysis-field{margin-bottom:15px}.analysis-field label{color:#333;display:block;font-weight:500;margin-bottom:5px}.analysis-field input,.analysis-field textarea{border:2px solid #e0e0e0;border-radius:6px;font-family:inherit;font-size:1rem;padding:10px;width:100%}.analysis-field input:focus,.analysis-field textarea:focus{border-color:#667eea;outline:none}.analysis-actions{display:flex;gap:10px;justify-content:flex-end}.error-actions{flex-wrap:wrap}.error-actions,.error-actions-header{display:flex;gap:10px}.btn-ai{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff}.btn-small{font-size:.85rem;padding:6px 12px}@media (max-width:768px){.error-stats{flex-direction:column;gap:15px}.error-answers{grid-template-columns:1fr}.error-card-header{align-items:flex-start}.error-actions,.error-card-header{flex-direction:column}.error-actions .btn{width:100%}}.App{background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.container{margin:0 auto;max-width:1200px;padding:20px}.card{background:#fff;border-radius:12px;box-shadow:0 10px 30px #0003;margin-bottom:20px;padding:30px}.btn{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:12px 24px;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{box-shadow:0 5px 15px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#6c757d;color:#fff}.btn-success{background:#28a745;color:#fff}.btn-danger{background:#dc3545;color:#fff}.btn-large{font-size:18px;padding:16px 32px}h1,h2,h3{color:#333;margin-bottom:20px}.text-center{text-align:center}.mt-20{margin-top:20px}.mb-20{margin-bottom:20px}.loading{align-items:center;color:#fff;display:flex;font-size:24px;justify-content:center;min-height:50vh}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:40px;margin:0 auto 20px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
/*# sourceMappingURL=main.de2af05b.css.map*/