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;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*{box-sizing:border-box}.App{min-height:100vh}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{animation:fadeIn .5s ease-in;background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:450px;padding:40px;width:100%}.login-header{margin-bottom:30px;text-align:center}.login-header h1{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:2.5rem;margin:0 0 10px}.login-header p{color:#666;font-size:1.1rem;margin:0}.login-form{margin-bottom:30px}.login-form .form-group{margin-bottom:20px}.login-form label{color:#333;display:block;font-size:.95rem;font-weight:600;margin-bottom:8px}.login-form input{border:2px solid #e0e0e0;border-radius:10px;box-sizing:border-box;font-size:1rem;padding:12px 16px;transition:all .3s ease;width:100%}.login-form input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.btn-login{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:10px;padding:14px;transition:all .3s ease;width:100%}.btn-login:hover{box-shadow:0 10px 25px #667eea66;transform:translateY(-2px)}.btn-login:active{transform:translateY(0)}.login-info{background:#f8f9fa;border-left:4px solid #667eea;border-radius:10px;padding:20px}.info-title{color:#333;font-size:.95rem;font-weight:600;margin:0 0 12px}.credentials{display:flex;flex-direction:column;gap:8px}.credential-item{background:#fff;border-radius:6px;color:#666;font-family:Courier New,monospace;font-size:.9rem;padding:8px 12px}.credential-item strong{color:#667eea;margin-right:8px}.error-message{background:#fee;border-left:4px solid #c33;border-radius:8px;font-size:.95rem;margin-bottom:15px}@media (max-width:768px){.login-card{padding:30px 20px}.login-header h1{font-size:2rem}}.quiz-container{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);min-height:100vh;padding:30px 20px 20px}.quiz-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 30px #667eea4d;color:#fff;margin-bottom:40px;padding:30px 20px;text-align:center}.quiz-header h1{font-size:2.2rem;font-weight:700;margin:0 0 10px;text-shadow:0 2px 4px #0000001a}.quiz-details{color:#ffffffe6;font-size:1.1rem;font-weight:500;margin-bottom:0;text-align:center}.quiz-progress{background:#fff;border-radius:10px;box-shadow:0 2px 8px #0000000f;margin-bottom:20px;padding:12px 16px}.progress-bar{background:#e8ecf1;border-radius:8px;box-shadow:inset 0 1px 3px #0000000f;height:8px;margin-bottom:8px;overflow:hidden}.progress-fill{background:linear-gradient(90deg,#667eea,#764ba2);border-radius:8px;box-shadow:0 1px 4px #667eea66;height:100%;transition:width .4s cubic-bezier(.4,0,.2,1)}.question-counter{color:#666;font-size:.85rem;font-weight:500;text-align:center}.question-navigation{flex-wrap:wrap;gap:8px;margin-bottom:20px}.nav-dot,.question-navigation{display:flex;justify-content:center}.nav-dot{align-items:center;background:#fff;border:2px solid #ddd;border-radius:8px;box-shadow:0 1px 4px #0000000f;color:#666;cursor:pointer;font-size:.85rem;font-weight:600;height:36px;transition:all .3s cubic-bezier(.4,0,.2,1);width:36px}.nav-dot:hover{box-shadow:0 2px 8px #0000001f;transform:translateY(-2px)}.nav-dot.active{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;box-shadow:0 2px 10px #667eea4d;color:#fff;transform:scale(1.05)}.nav-dot.answered{background:linear-gradient(135deg,#11998e,#38ef7d);border-color:#38ef7d;color:#fff}.question-box{background:#fff;border-left:5px solid #667eea;border-radius:15px;box-shadow:0 4px 20px #00000014;margin-bottom:30px;padding:30px;transition:all .3s ease}.question-box:hover{box-shadow:0 6px 25px #0000001f}.question-box h3{color:#2c3e50;font-size:1.3rem;font-weight:600;line-height:1.6;margin:0}.answer-textarea{border:2px solid #e0e0e0;border-radius:10px;font-family:inherit;font-size:16px;margin-bottom:20px;min-height:150px;padding:15px;resize:vertical;transition:border-color .3s;width:100%}.answer-textarea:focus{border-color:#667eea;outline:none}.quiz-controls{align-items:center;display:flex;flex-wrap:wrap;gap:15px;justify-content:space-between;margin-top:30px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 15px #667eea4d;font-size:16px;font-weight:600;overflow:hidden;padding:14px 32px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-primary:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.btn-primary:hover:before{left:100%}.btn-primary:hover:not(:disabled){box-shadow:0 6px 25px #667eea66;transform:translateY(-3px)}.btn-primary:active:not(:disabled){transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-secondary{background:linear-gradient(135deg,#11998e,#38ef7d);border-radius:12px;box-shadow:0 4px 15px #11998e4d;font-size:16px;font-weight:600;padding:14px 32px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-secondary:hover:not(:disabled){box-shadow:0 6px 25px #11998e66;transform:translateY(-3px)}.btn-secondary:disabled{cursor:not-allowed;opacity:.6;transform:none}.submit-btn{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 15px #f5576c4d}.submit-btn:hover:not(:disabled){box-shadow:0 6px 25px #f5576c66}.form-group label{color:#333;margin-bottom:8px}.form-group input{border:2px solid #e0e0e0;border-radius:8px;padding:12px;transition:border-color .3s}.error-message{animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:768px){.quiz-container{padding:10px}.student-info-card{margin:20px auto;padding:20px}.quiz-progress{margin-bottom:15px;padding:10px 12px}.question-counter{font-size:.8rem}.question-navigation{gap:6px;margin-bottom:15px}.nav-dot{font-size:.8rem;height:32px;width:32px}.quiz-controls{flex-direction:column}.btn-primary,.btn-secondary{width:100%}}.answer-options{margin-bottom:25px}.option-item{background:#fff;border:2px solid #e0e0e0;border-radius:10px;cursor:pointer;margin-bottom:12px;padding:15px;transition:all .3s}.option-item:hover{background:#f8f9ff;border-color:#667eea}.option-item label{align-items:center;cursor:pointer;display:flex;width:100%}.option-item input[type=radio]{cursor:pointer;height:20px;margin-right:12px;width:20px}.option-text{color:#333;flex:1 1;font-size:16px}.option-item:has(input:checked){background:#f0f3ff;border-color:#667eea}.results-header{border-radius:15px;margin-bottom:30px;padding:30px 20px}.results-header h1{font-size:2rem;margin:0 0 10px}.results-header h2{font-size:1.5rem;margin:0 0 5px}.score-card{border-radius:15px;margin-bottom:30px;padding:40px}.score-percentage{font-size:4rem;font-weight:700;margin-bottom:10px}.score-label{font-size:1.5rem;font-weight:600;margin-bottom:10px}.score-details{color:#666;font-size:1.1rem}.score-card.excellent .score-percentage{color:#27ae60}.score-card.good .score-percentage{color:#3498db}.score-card.fair .score-percentage{color:#f39c12}.score-card.poor .score-percentage{color:#e74c3c}.detailed-results{border-radius:15px;box-shadow:0 5px 20px #0000000d;margin-bottom:30px;padding:30px}.detailed-results h3{color:#333;font-size:1.5rem;margin-bottom:25px}.result-item{border:2px solid #e0e0e0;border-radius:12px;margin-bottom:20px;padding:20px;transition:all .3s}.result-item.correct{background:#f0fff4;border-color:#27ae60}.result-item.incorrect{background:#fff5f5;border-color:#e74c3c}.result-header{gap:10px;margin-bottom:15px}.question-number{color:#666}.question-number,.result-badge{font-size:.9rem;font-weight:600}.result-badge{border-radius:20px;padding:6px 12px}.result-badge.correct{background:#27ae60;color:#fff}.result-badge.incorrect{background:#e74c3c;color:#fff}.question-text{color:#333;font-size:1.1rem;font-weight:500;margin-bottom:15px}.answer-review{gap:10px}.correct-answer,.your-answer{display:flex;flex-direction:column;gap:5px}.correct-answer strong,.your-answer strong{color:#666;font-size:.9rem}.correct-text{background:#f0fff4;border-left:3px solid #27ae60;color:#27ae60}.correct-text,.incorrect-text{border-radius:6px;font-weight:500;padding:8px 12px}.incorrect-text{background:#fff5f5;border-left:3px solid #e74c3c;color:#e74c3c}.results-actions{gap:15px}@media (max-width:768px){.results-header h1{font-size:1.5rem}.results-header h2{font-size:1.2rem}.score-percentage{font-size:3rem}.score-label{font-size:1.2rem}.detailed-results{padding:20px}.result-item{padding:15px}.results-actions{flex-direction:column}.results-actions button{width:100%}}.elaborate-answer{background:#fff;border-radius:15px;box-shadow:0 4px 20px #00000014;padding:25px}.elaborate-answer textarea{border:2px solid #e8ecf1;border-radius:12px;font-family:inherit;font-size:16px;line-height:1.6;margin-bottom:15px;min-height:180px;padding:18px;resize:vertical;transition:all .3s ease;width:100%}.elaborate-answer textarea:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.elaborate-answer textarea:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.7}.pdf-upload-section{margin-top:25px}.upload-divider{margin:25px 0;position:relative;text-align:center}.upload-divider:after,.upload-divider:before{background:linear-gradient(90deg,#0000,#e8ecf1,#0000);content:"";height:2px;position:absolute;top:50%;width:42%}.upload-divider:before{left:0}.upload-divider:after{right:0}.upload-divider span{background:#fff;color:#999;font-size:.9rem;font-weight:600;letter-spacing:1px;padding:0 20px;text-transform:uppercase}.pdf-upload-container{margin-top:20px}.pdf-upload-input{text-align:center}.btn-upload{background:linear-gradient(135deg,#11998e,#38ef7d);border:none;border-radius:12px;box-shadow:0 4px 15px #11998e4d;color:#fff;cursor:pointer;display:inline-block;font-size:16px;font-weight:600;padding:14px 28px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-upload:hover{box-shadow:0 6px 25px #11998e66;transform:translateY(-3px)}.upload-hint{color:#999;font-size:13px;font-weight:500;margin-top:10px}.pdf-uploaded{align-items:center;animation:fadeIn .3s ease-out;background:linear-gradient(135deg,#f0fff4,#e6f9ed);border:2px solid #27ae60;border-radius:12px;display:flex;gap:12px;justify-content:center;padding:18px}@keyframes fadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.pdf-icon{font-size:28px}.pdf-name{color:#2c3e50;flex:1 1;font-weight:600;word-break:break-word}.btn-remove-pdf{align-items:center;background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:50%;box-shadow:0 2px 8px #e74c3c4d;color:#fff;cursor:pointer;display:flex;font-size:18px;height:35px;justify-content:center;transition:all .3s ease;width:35px}.btn-remove-pdf:hover{background:linear-gradient(135deg,#c0392b,#a93226);box-shadow:0 4px 12px #e74c3c66;transform:scale(1.1)}.example-answer-hint{background:linear-gradient(135deg,#f8f9fa,#e8ecf1);border-left:5px solid #667eea;border-radius:12px;box-shadow:0 2px 10px #0000000d;margin-top:25px;padding:20px}.example-answer-hint strong{color:#667eea;display:block;font-size:1rem;font-weight:700;margin-bottom:10px}.example-answer-hint p{color:#555;font-size:.95rem;line-height:1.7;margin:0}.result-item.elaborate{background:#f8f9ff}.result-badge.score{background:#667eea}.answer-text{border:1px solid #e0e0e0;border-radius:8px;line-height:1.6;padding:12px}.example-answer{margin-top:15px}.evaluation-section,.justification-section,.suggestions-section{border-left:4px solid #667eea;border-radius:8px;margin-top:15px;padding:15px}.evaluation-text,.justification-text,.suggestions-text{line-height:1.6}@media (max-width:768px){.quiz-container{padding:15px}.quiz-header{margin-bottom:30px;padding:25px 15px}.quiz-header h1{font-size:1.8rem}.quiz-details{font-size:1rem}.quiz-progress{padding:15px}.question-navigation{gap:8px}.nav-dot{font-size:.9rem;height:40px;width:40px}.question-box{padding:20px}.question-box h3{font-size:1.1rem}.elaborate-answer{padding:18px}.elaborate-answer textarea{font-size:15px;min-height:150px;padding:15px}.btn-primary,.btn-secondary,.submit-btn{font-size:15px;padding:12px 24px}.quiz-controls{flex-direction:column;gap:12px}.quiz-controls button{width:100%}.pdf-uploaded{padding:15px}.pdf-icon{font-size:24px}.pdf-name{font-size:.9rem}}@media (min-width:769px) and (max-width:1024px){.quiz-container{padding:25px}.question-box{padding:28px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.elaborate-answer,.question-box,.quiz-header,.quiz-progress{animation:fadeInUp .5s ease-out}.quiz-progress{animation-delay:.1s}.question-box{animation-delay:.2s}.elaborate-answer{animation-delay:.3s}.student-info-card{animation:fadeInUp .5s ease-out;background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001f;margin:80px auto;max-width:550px;padding:45px}.student-info-card h2{color:#2c3e50;font-size:2rem;font-weight:700;margin-bottom:15px;text-align:center}.student-info-card .quiz-details{color:#7f8c8d;font-size:1.1rem;font-weight:500;margin-bottom:10px;text-align:center}.form-group{margin:30px 0}.form-group label{color:#2c3e50;font-size:1rem;font-weight:600;margin-bottom:10px}.form-group input{border:2px solid #e8ecf1;border-radius:12px;font-family:inherit;font-size:16px;padding:15px;transition:all .3s ease;width:100%}.form-group input:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.form-group input::placeholder{color:#bdc3c7}.quiz-controls-header{background:#fff;border-radius:15px;box-shadow:0 4px 20px #00000014;gap:15px;justify-content:space-between;margin-bottom:30px;padding:20px 25px}.quiz-controls-header,.quiz-info{align-items:center;display:flex;flex-wrap:wrap}.quiz-info{gap:12px}.quiz-course,.quiz-subject{background:linear-gradient(135deg,#f8f9fa,#e8ecf1);border-radius:8px;color:#2c3e50;font-size:1rem;font-weight:600;padding:8px 16px}.quiz-separator{color:#bdc3c7;font-size:1.2rem;font-weight:600}.quiz-controls-header .quiz-controls{display:flex;gap:12px;margin:0}@media (max-width:768px){.quiz-controls-header{flex-direction:column;gap:20px;padding:18px}.quiz-info{justify-content:center;width:100%}.quiz-controls-header .quiz-controls{flex-direction:column;gap:12px;width:100%}.quiz-controls-header .quiz-controls button{width:100%}.quiz-course,.quiz-subject{font-size:.9rem;padding:6px 12px}}.results-header{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:20px;box-shadow:0 10px 40px #667eea4d;color:#fff;margin-bottom:40px;padding:40px 20px;text-align:center}.results-header h1{font-size:2.5rem;font-weight:700;margin:0 0 12px;text-shadow:0 2px 4px #0000001a}.results-header h2{font-size:1.6rem;font-weight:600;margin:0 0 8px;opacity:.95}.score-card{background:#fff;border-radius:20px;box-shadow:0 10px 40px #0000001a;margin-bottom:40px;overflow:hidden;padding:50px 40px;position:relative;text-align:center}.score-card:before{background:linear-gradient(90deg,#667eea,#764ba2);content:"";height:5px;left:0;position:absolute;right:0;top:0}.score-percentage{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;font-size:5rem;font-weight:800;margin-bottom:15px}.score-label{color:#2c3e50;font-size:1.8rem;font-weight:700;margin-bottom:12px}.score-details{color:#7f8c8d;font-size:1.2rem;font-weight:500}.score-card.excellent .score-percentage{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#27ae60,#2ecc71);-webkit-background-clip:text;background-clip:text}.score-card.good .score-percentage{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3498db,#5dade2);-webkit-background-clip:text;background-clip:text}.score-card.fair .score-percentage{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#f39c12,#f5b041);-webkit-background-clip:text;background-clip:text}.score-card.poor .score-percentage{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#e74c3c,#ec7063);-webkit-background-clip:text;background-clip:text}.detailed-results{background:#fff;border-radius:20px;box-shadow:0 5px 25px #00000014;margin-bottom:40px;padding:35px}.detailed-results h3{border-bottom:3px solid #667eea;color:#2c3e50;font-size:1.8rem;font-weight:700;margin-bottom:30px;margin-top:0;padding-bottom:15px}.result-item{background:#fafbfc;border:2px solid #e8ecf1;border-radius:15px;margin-bottom:25px;padding:25px;transition:all .3s ease}.result-item:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.result-item.elaborate{background:linear-gradient(135deg,#f8f9ff,#f0f3ff);border-color:#667eea}.result-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:18px}.question-number{color:#667eea;font-size:1rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.result-badge{border-radius:25px;box-shadow:0 2px 8px #00000026;font-size:.95rem;font-weight:700;padding:8px 16px}.result-badge.score{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.question-text{color:#2c3e50;font-size:1.2rem;font-weight:600;line-height:1.6;margin-bottom:18px}.answer-review{display:flex;flex-direction:column;gap:15px}.example-answer,.your-answer{display:flex;flex-direction:column;gap:8px}.example-answer strong,.your-answer strong{color:#7f8c8d;font-size:.95rem;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.answer-text{word-wrap:break-word;background:#fff;border:2px solid #e8ecf1;border-radius:10px;box-shadow:0 2px 8px #0000000d;color:#2c3e50;line-height:1.7;margin-top:8px;padding:15px;white-space:pre-wrap}.evaluation-section,.justification-section,.suggestions-section{background:#fff;border-left:5px solid #667eea;border-radius:12px;box-shadow:0 2px 10px #0000000d;margin-top:18px;padding:18px}.evaluation-section strong,.justification-section strong,.suggestions-section strong{color:#2c3e50;display:block;font-size:1rem;font-weight:700;margin-bottom:10px}.evaluation-text,.justification-text,.suggestions-text{color:#555;font-size:.95rem;line-height:1.7;margin-top:8px}.justification-section{border-left-color:#3498db}.suggestions-section{border-left-color:#27ae60}.results-actions{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}@media (max-width:768px){.results-header h1{font-size:1.8rem}.results-header h2{font-size:1.3rem}.score-percentage{font-size:3.5rem}.score-label{font-size:1.4rem}.detailed-results{padding:20px}.result-item{padding:18px}.results-actions{flex-direction:column}.results-actions button{width:100%}}.results-report-container{background:linear-gradient(135deg,#f5f7fa,#e8ecf1);min-height:100vh;padding:30px 20px}.report-header{align-items:center;display:flex;flex-wrap:wrap;gap:20px;justify-content:space-between;margin-bottom:30px}.report-header h1{color:#2c3e50;font-size:2.5rem;font-weight:700;margin:0}.btn-back{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 4px 15px #667eea4d;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-back:hover{box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.filters-card{background:#fff;border-radius:20px;box-shadow:0 5px 25px #00000014;margin-bottom:30px;padding:30px}.filters-card h3{color:#2c3e50;font-size:1.5rem;font-weight:700;margin-bottom:20px;margin-top:0}.filters-grid{grid-gap:20px;align-items:end;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.filter-group{display:flex;flex-direction:column}.filter-group label{color:#2c3e50;font-size:.95rem;font-weight:600;margin-bottom:8px}.filter-group input,.filter-group select{border:2px solid #e8ecf1;border-radius:10px;font-family:inherit;font-size:15px;padding:12px 15px;transition:all .3s ease}.filter-group input:focus,.filter-group select:focus{border-color:#667eea;box-shadow:0 0 0 4px #667eea1a;outline:none}.filter-actions{align-items:flex-end;display:flex}.btn-clear{background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:10px;box-shadow:0 4px 15px #e74c3c4d;color:#fff;cursor:pointer;font-size:15px;font-weight:600;padding:12px 24px;transition:all .3s ease}.btn-clear:hover{box-shadow:0 6px 20px #e74c3c66;transform:translateY(-2px)}.results-summary{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));margin-bottom:30px}.summary-card{align-items:center;background:#fff;border-radius:15px;box-shadow:0 5px 20px #00000014;display:flex;gap:20px;padding:25px;transition:all .3s ease}.summary-card:hover{box-shadow:0 8px 30px #0000001f;transform:translateY(-5px)}.summary-icon{font-size:3rem;line-height:1}.summary-content{flex:1 1}.summary-value{color:#2c3e50;font-size:2rem;font-weight:800;margin-bottom:5px}.summary-label{color:#7f8c8d;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.results-table-card{background:#fff;border-radius:20px;box-shadow:0 5px 25px #00000014;padding:30px}.results-table-card h3{color:#2c3e50;font-size:1.5rem;font-weight:700;margin-bottom:25px;margin-top:0}.table-responsive{overflow-x:auto}.results-table{border-collapse:collapse;width:100%}.results-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.results-table th{font-size:.95rem;font-weight:700;letter-spacing:.5px;padding:15px;text-align:left;text-transform:uppercase}.results-table tbody tr{border-bottom:1px solid #e8ecf1;transition:all .3s ease}.results-table tbody tr:hover{background:#f8f9ff}.results-table td{color:#2c3e50;font-size:.95rem;padding:15px}.student-name{color:#667eea;font-weight:600}.score-badge{border-radius:20px;display:inline-block;font-size:.9rem;font-weight:700;padding:6px 14px}.score-badge.excellent{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff}.score-badge.good{background:linear-gradient(135deg,#3498db,#5dade2);color:#fff}.score-badge.fair{background:linear-gradient(135deg,#f39c12,#f5b041);color:#fff}.score-badge.poor{background:linear-gradient(135deg,#e74c3c,#ec7063);color:#fff}.text-center{text-align:center}.date-cell{color:#7f8c8d;font-size:.85rem}.no-results{color:#7f8c8d;padding:60px 20px;text-align:center}.no-results p{font-size:1.1rem;margin:0}.loading{padding:80px 20px}.spinner{animation:spin .8s linear infinite;border:5px solid #f3f3f3;border-radius:50%;border-top-color:#667eea;height:50px;margin:0 auto 20px;width:50px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.error-message{background:linear-gradient(135deg,#fee,#fdd);border:2px solid #fcc;border-radius:12px;box-shadow:0 4px 15px #cc333326;color:#c33;font-weight:500;margin-bottom:25px;padding:18px 20px}@media (max-width:768px){.report-header{align-items:flex-start;flex-direction:column}.report-header h1{font-size:1.8rem}.filters-grid,.results-summary{grid-template-columns:1fr}.results-table{font-size:.85rem}.results-table td,.results-table th{padding:10px 8px}}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f0f4ff!important}.btn-delete-small{background:linear-gradient(135deg,#e74c3c,#c0392b);border:none;border-radius:8px;box-shadow:0 2px 8px #e74c3c4d;color:#fff;cursor:pointer;font-size:16px;padding:6px 12px;transition:all .3s ease}.btn-delete-small:hover{box-shadow:0 4px 12px #e74c3c80;transform:scale(1.1)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;padding:20px}.modal-content{animation:modalSlideIn .3s ease;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:900px;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-30px)}to{opacity:1;transform:translateY(0)}}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:2px solid #e8ecf1;border-radius:20px 20px 0 0;color:#fff;padding:25px 30px}.modal-header h2{font-size:1.8rem;font-weight:700;margin:0}.btn-close{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:24px;height:36px;justify-content:center;transition:all .3s ease;width:36px}.btn-close:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-body{padding:30px}.detail-info{background:#f8f9ff;border-radius:15px;margin-bottom:30px;padding:25px}.info-row{align-items:center;border-bottom:1px solid #e8ecf1;display:flex;justify-content:space-between;padding:12px 0}.info-row:last-child{border-bottom:none}.info-label{color:#2c3e50;font-size:1rem;font-weight:700}.info-value{color:#667eea;font-size:1rem;font-weight:600}.questions-answers h3{color:#2c3e50;font-size:1.5rem;font-weight:700;margin-bottom:20px}.qa-card{background:#f8f9ff;border:2px solid #e8ecf1;border-radius:15px;margin-bottom:20px;padding:20px;transition:all .3s ease}.qa-card:hover{border-color:#667eea;box-shadow:0 5px 20px #667eea26}.qa-header{align-items:center;border-bottom:2px solid #e8ecf1;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:15px}.qa-number{color:#2c3e50;font-size:1.1rem;font-weight:700}.qa-score{border-radius:20px;font-size:.9rem;font-weight:700;padding:6px 14px}.qa-content{display:flex;flex-direction:column;gap:15px}.qa-section{background:#fff;border-left:4px solid #667eea;border-radius:10px;padding:15px}.qa-section.question-section{background:linear-gradient(135deg,#f8f9ff,#e8ecff);border-left:4px solid #764ba2;font-weight:500}.qa-section strong{color:#2c3e50;display:block;font-size:.95rem;margin-bottom:8px}.qa-section p{color:#555;font-size:.95rem;line-height:1.6;margin:0}.confirm-modal{max-width:500px}.confirm-details{background:#f8f9ff;border-radius:10px;margin:20px 0;padding:20px}.confirm-details p{color:#2c3e50;font-size:1rem;margin:8px 0}.warning-text{color:#e74c3c;font-weight:600;margin-top:15px;text-align:center}.modal-footer{border-top:2px solid #e8ecf1;display:flex;gap:15px;justify-content:flex-end;padding:20px 30px}.btn-cancel{background:#95a5a6;border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:16px;font-weight:600;padding:12px 30px;transition:all .3s ease}.btn-cancel:hover{background:#7f8c8d;transform:translateY(-2px)}.btn-delete{background:linear-gradient(135deg,#e74c3c,#c0392b);border-radius:10px;box-shadow:0 4px 15px #e74c3c4d;font-size:16px;font-weight:600;padding:12px 30px;transition:all .3s ease}.btn-delete:hover{box-shadow:0 6px 20px #e74c3c80;transform:translateY(-2px)}@media (max-width:768px){.modal-content{margin:10px;max-width:100%}.modal-header h2{font-size:1.4rem}.info-row{gap:5px}.info-row,.qa-header{align-items:flex-start;flex-direction:column}.qa-header{gap:10px}}.user-management{margin:0 auto;max-width:1200px;padding:20px}.user-management-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.user-management-header h2{color:#333;margin:0}.filters{background:#f5f5f5;border-radius:8px;margin-bottom:20px;padding:15px}.filters label{align-items:center;display:flex;font-weight:500;gap:10px}.filters select{border:1px solid #ddd;border-radius:4px;font-size:14px;padding:8px 12px}.users-table-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;overflow-x:auto}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:#f8f9fa}.users-table th{border-bottom:2px solid #dee2e6;color:#555;font-weight:600;padding:12px;text-align:left}.users-table td{border-bottom:1px solid #dee2e6;padding:12px}.users-table tbody tr:hover{background:#f8f9fa}.no-data{color:#999;padding:40px!important;text-align:center}.role-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px;text-transform:uppercase}.role-admin{background:#dc3545;color:#fff}.role-tutor{background:#007bff;color:#fff}.role-student{background:#28a745;color:#fff}.status-badge{border-radius:12px;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.status-badge.active{background:#d4edda;color:#155724}.status-badge.inactive{background:#f8d7da;color:#721c24}.actions{display:flex;gap:8px}.btn-primary{background:#007bff;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background .2s}.btn-primary:hover{background:#0056b3}.btn-secondary{background:#6c757d;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:background .2s}.btn-secondary:hover{background:#545b62}.btn-edit{background:#ffc107;border:none;border-radius:4px;color:#000;cursor:pointer;font-size:13px;padding:6px 12px;transition:background .2s}.btn-edit:hover{background:#e0a800}.btn-delete{background:#dc3545;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:13px;padding:6px 12px;transition:background .2s}.btn-delete:hover{background:#c82333}.modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;max-height:90vh;max-width:500px;overflow-y:auto;width:90%}.modal-header{align-items:center;border-bottom:1px solid #dee2e6;display:flex;justify-content:space-between;padding:20px}.modal-header h3{color:#333;margin:0}.modal-close{background:none;border:none;color:#999;cursor:pointer;font-size:28px;height:30px;line-height:1;padding:0;width:30px}.modal-close:hover{color:#333}.user-form{padding:20px}.form-group{margin-bottom:20px}.form-group label{color:#555;display:block;font-weight:500;margin-bottom:5px}.form-group input,.form-group select{border:1px solid #ddd;border-radius:4px;box-sizing:border-box;font-size:14px;padding:10px;width:100%}.form-group input:focus,.form-group select:focus{border-color:#007bff;outline:none}.form-group input:disabled{background:#f5f5f5;cursor:not-allowed}.form-group small{color:#666;display:block;font-size:12px;margin-top:5px}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:8px}.checkbox-group input[type=checkbox]{cursor:pointer;width:auto}.form-actions{border-top:1px solid #dee2e6;display:flex;gap:10px;justify-content:flex-end;margin-top:20px;padding-top:20px}.loading{color:#666;padding:40px;text-align:center}.error-message{background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24;margin-bottom:20px;padding:12px}
/*# sourceMappingURL=main.c4776d75.css.map*/