*,body{margin:0}*{box-sizing:border-box;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f7fa;color:#2c3e50;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--primary-color:#3498db;--primary-dark:#2980b9;--secondary-color:#2ecc71;--secondary-dark:#27ae60;--danger-color:#e74c3c;--danger-dark:#c0392b;--warning-color:#f39c12;--warning-dark:#e67e22;--success-color:#2ecc71;--success-dark:#27ae60;--info-color:#3498db;--info-dark:#2980b9;--light-color:#ecf0f1;--dark-color:#2c3e50;--gray-color:#7f8c8d;--border-radius:8px;--box-shadow:0 2px 10px #0000001a;--transition:all 0.3s ease}.app-container{display:flex;flex-direction:column;min-height:100vh}.header{background:linear-gradient(135deg,#3498db,#2980b9);background:linear-gradient(135deg,var(--primary-color),var(--primary-dark));box-shadow:0 2px 10px #0000001a;box-shadow:var(--box-shadow);color:#fff;padding:1rem 2rem}.header-content{margin:0 auto;max-width:1200px}.logo{font-size:1.5rem;font-weight:700}.header-actions{gap:1rem}.nav{background:#fff;box-shadow:0 2px 4px #0000001a;padding:0 2rem}.nav-content{display:flex;gap:2rem;margin:0 auto;max-width:1200px}.nav-item{border-bottom:3px solid #0000;color:#2c3e50;color:var(--dark-color);padding:1rem 0;text-decoration:none;transition:all .3s ease;transition:var(--transition)}.nav-item.active,.nav-item:hover{border-bottom-color:#3498db;border-bottom-color:var(--primary-color);color:#3498db;color:var(--primary-color)}.main-content{flex:1 1;margin:0 auto;max-width:1200px;padding:2rem;width:100%}.card{background:#fff;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 10px #0000001a;box-shadow:var(--box-shadow);margin-bottom:1.5rem;padding:1.5rem;transition:all .3s ease;transition:var(--transition)}.card:hover{box-shadow:0 4px 20px #00000026}.card-header{align-items:center;border-bottom:1px solid #ecf0f1;border-bottom:1px solid var(--light-color);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.card-title{color:#2c3e50;color:var(--dark-color);font-size:1.25rem;font-weight:600}.card-content{margin-bottom:1rem}.card-actions{display:flex;gap:1rem;justify-content:flex-end}.btn{align-items:center;border:none;border-radius:8px;border-radius:var(--border-radius);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;gap:.5rem;justify-content:center;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease;transition:var(--transition)}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#3498db;background:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background:#2980b9;background:var(--primary-dark)}.btn-secondary{background:#2ecc71;background:var(--secondary-color);color:#fff}.btn-secondary:hover:not(:disabled){background:#27ae60;background:var(--secondary-dark)}.btn-danger{background:#e74c3c;background:var(--danger-color);color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b;background:var(--danger-dark)}.btn-success{background:#2ecc71;background:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background:#27ae60;background:var(--success-dark)}.btn-outline{background:#0000;border:2px solid #3498db;border:2px solid var(--primary-color);color:#3498db;color:var(--primary-color)}.btn-outline:hover:not(:disabled){background:#3498db;background:var(--primary-color);color:#fff}.btn-sm{font-size:.875rem;padding:.5rem 1rem}.btn-lg{font-size:1.125rem;padding:1rem 2rem}.form-label{color:#2c3e50;color:var(--dark-color);font-weight:500}.form-input{border:2px solid #ecf0f1;border:2px solid var(--light-color);border-radius:8px;border-radius:var(--border-radius);transition:var(--transition)}.form-input:focus{border-color:#3498db;border-color:var(--primary-color);box-shadow:0 0 0 3px #3498db1a}.form-input.error{border-color:#e74c3c;border-color:var(--danger-color)}.form-error{color:#e74c3c;color:var(--danger-color);font-size:.875rem;margin-top:.25rem}.form-textarea{min-height:100px;resize:vertical}.status-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:.875rem;font-weight:500}.status-created{background:#f8f9fa;color:#7f8c8d;color:var(--gray-color)}.status-active{background:#d4edda;color:#27ae60;color:var(--success-dark)}.status-paused{background:#fff3cd;color:#e67e22;color:var(--warning-dark)}.status-ended{background:#f8d7da;color:#c0392b;color:var(--danger-dark)}.grid{grid-gap:1.5rem;display:grid;gap:1.5rem}.grid-2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.grid-3{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.p-1{padding:.5rem}.p-2{padding:1rem}.p-3{padding:1.5rem}.p-4{padding:2rem}.flex{display:flex}.flex-column{flex-direction:column}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.align-center{align-items:center}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.loading{align-items:center;display:flex;justify-content:center;padding:2rem}.spinner{animation:spin 1s linear infinite;border:4px solid #ecf0f1;border-top:4px solid #3498db;border:4px solid var(--light-color);border-radius:50%;border-top-color:var(--primary-color);height:40px;width:40px}@media (max-width:768px){.header{padding:1rem}.header-content{flex-direction:column;gap:1rem}.card,.main-content{padding:1rem}.grid-2,.grid-3{grid-template-columns:1fr}.card-actions{flex-direction:column}.btn{justify-content:center;width:100%}}.fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slideIn .3s ease-out}@keyframes slideIn{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.teacher-info{align-items:flex-end;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:4px;display:flex;flex-direction:column;margin-right:.75rem;padding:0}.teacher-name{align-items:center;color:#ffffffe6;display:flex;font-size:.7rem;font-weight:600;gap:.25rem;text-shadow:none}.teacher-name i{color:#ffffffb3;font-size:.6rem}.teacher-stats{color:#fff9;font-size:.7rem;font-weight:400;margin-top:.5px;text-shadow:none}.header{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #ffffff14;box-shadow:0 2px 10px #0000000d;min-height:auto;padding:.75rem 1rem}.header .logo{color:#ffffffe6;font-size:1.1rem;font-weight:600;text-shadow:none}.header .btn{-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff14;border:1px solid #ffffff26;color:#fffc;font-size:.8rem;padding:.4rem .6rem;transition:all .2s ease}.header .btn:hover{background:#ffffff1f;border-color:#ffffff40;box-shadow:0 2px 8px #0000001a;color:#fffffff2;transform:none}.header .btn i{color:#ffffffb3;font-size:.8rem}.form-text{color:#666;font-size:.8rem;margin-top:.25rem}.spinner-border-sm{height:1rem;width:1rem}.alert{border:1px solid #0000;border-radius:.375rem;margin-bottom:1rem;padding:.75rem 1rem}.alert-info{background-color:#d1ecf1;border-color:#bee5eb;color:#0c5460}.alert-danger{background-color:#f8d7da;border-color:#f5c6cb;color:#721c24}.header-content{align-items:center;display:flex;justify-content:space-between;width:100%}.header-actions{align-items:center;display:flex;flex-wrap:wrap;gap:.5rem}@media (max-width:768px){.header{padding:.5rem .75rem}.header-content{align-items:center;flex-direction:column;gap:.75rem}.header .logo{font-size:1rem;text-align:center}.header-actions{flex-wrap:wrap;gap:.5rem;justify-content:center}.header .btn{font-size:.7rem;padding:.3rem .5rem}.status-badge{font-size:.65rem;padding:.2rem .4rem}.text-white{font-size:.7rem}}@media (max-width:480px){.header{padding:.4rem .5rem}.header .logo{font-size:.9rem}.header-actions{gap:.3rem}.header .btn{font-size:.65rem;padding:.25rem .4rem}.status-badge{font-size:.6rem;padding:.15rem .3rem}.text-white{font-size:.65rem}}@media (max-width:360px){.header .logo{font-size:.8rem}.header .btn{font-size:.6rem;padding:.2rem .3rem}.status-badge{font-size:.55rem;padding:.1rem .25rem}.text-white{font-size:.6rem}.header-actions .btn:first-child{display:inline-block}}.session-statistics,.student-statistics{margin-top:0}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1rem}.stat-item{background:#4facfe0d;border:1px solid #4facfe1a;border-radius:8px;padding:1rem;text-align:center}.stat-number{color:#4facfe;font-size:2rem;font-weight:700;margin-bottom:.5rem}.stat-label{color:#666;font-size:.9rem}.question-stat{background:#f8f9fa;border-left:4px solid #4facfe;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.question-stat-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:.5rem;justify-content:space-between;margin-bottom:1rem}.question-stat-header h4{color:#333;font-size:1rem;margin:0}.question-stat-meta{display:flex;flex-wrap:wrap;gap:.5rem}.stat-badge{background:#4facfe1a;border-radius:4px;color:#4facfe;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.answer-distribution{margin-top:1rem}.distribution-chart{margin-top:.5rem}.distribution-item{align-items:center;background:#fff;border-radius:4px;display:flex;gap:.5rem;margin-bottom:.5rem;padding:.5rem}.distribution-label{color:#333;font-size:.9rem;min-width:100px}.distribution-bar{background:#e9ecef;border-radius:10px;flex:1 1;height:20px;overflow:hidden;position:relative}.distribution-fill{background:linear-gradient(90deg,#4facfe,#00f2fe);height:100%;transition:width .3s ease}.distribution-count{color:#4facfe;font-weight:700;min-width:30px;text-align:center}.rating-stats{margin-top:1rem}.rating-summary{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.rating-item{background:#4facfe1a;border-radius:4px;color:#4facfe;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.personal-response{background:#f8f9fa;border-left:4px solid #28a745;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.response-header{align-items:flex-start;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.response-header h4{color:#333;font-size:1rem;margin:0}.response-status{align-items:center;display:flex}.response-details{background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:.75rem}.response-details p{color:#333;margin:.5rem 0}.response-time{color:#666;font-size:.8rem;font-style:italic}.modification-info{color:#888;font-size:.8rem;font-style:italic;margin:.25rem 0}.unmatched-responses{background:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;margin-top:1rem;padding:.75rem}.unmatched-responses h6{color:#856404;font-size:.9rem;margin:0 0 .5rem}.unmatched-responses p{color:#856404;font-size:.8rem;margin:0}@media (max-width:768px){.stats-grid{gap:.75rem;grid-template-columns:repeat(2,1fr)}.stat-number{font-size:1.5rem}.question-stat-header,.response-header{align-items:flex-start;flex-direction:column}.question-stat-meta{margin-top:.5rem}.distribution-item{align-items:flex-start;flex-direction:column;gap:.25rem}.distribution-label{min-width:auto}.distribution-bar{width:100%}}@media (max-width:480px){.stats-grid{grid-template-columns:1fr}.stat-item{padding:.75rem}.stat-number{font-size:1.25rem}}.session-info{background:#4facfe0d;border:1px solid #4facfe1a;border-radius:8px;padding:1rem}.session-info p{color:#333;margin:.5rem 0}.session-info code{background:#4facfe1a;border-radius:4px;font-family:Courier New,monospace;font-size:.9rem;padding:.2rem .4rem}.status-badge{border-radius:12px;font-size:.8rem;font-weight:600;padding:.25rem .75rem;text-transform:uppercase}.status-badge.created{background:#6c757d1a;border:1px solid #6c757d33;color:#6c757d}.status-badge.active{background:#28a7451a;border:1px solid #28a74533;color:#28a745}.status-badge.paused{background:#ffc1071a;border:1px solid #ffc10733;color:#ffc107}.status-badge.ended{background:#dc35451a;border:1px solid #dc354533;color:#dc3545}.questions-list{display:flex;flex-direction:column;gap:1rem}.question-item{background:#4facfe0d;border:1px solid #4facfe1a;border-radius:8px;padding:1rem}.question-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}.question-header h4{color:#333;font-size:1.1rem;margin:0}.question-type{border-radius:6px;font-size:.75rem;font-weight:600;padding:.2rem .5rem;text-transform:uppercase}.question-type.multiple_choice{background:#4facfe1a;color:#4facfe}.question-type.open_ended{background:#28a7451a;color:#28a745}.question-type.true_false{background:#ffc1071a;color:#ffc107}.question-content{color:#666;line-height:1.5;margin:.5rem 0}.question-actions{display:flex;gap:.5rem;margin-top:.75rem}.grid-2{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr}@media (max-width:768px){.grid-2{gap:1rem;grid-template-columns:1fr}.question-header{align-items:flex-start;gap:.5rem}.question-actions,.question-header{flex-direction:column}}.question-form{margin:0 auto;max-width:800px}.form-label{color:#333;display:block;margin-bottom:.5rem}.form-input{border:1px solid #ddd;border-radius:6px;padding:.75rem;transition:border-color .2s ease}.form-input:focus{border-color:#4facfe;box-shadow:0 0 0 3px #4facfe1a}.form-input[type=number]{max-width:150px}.option-input-group{background-color:#fafbfc;border:1px solid #e1e8ed;border-radius:8px;border-radius:var(--border-radius);display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem;padding:1rem}.option-main{align-items:center;display:flex;gap:.75rem}.option-main .form-input{flex:1 1}.option-actions{align-items:center;display:flex;gap:.5rem}.option-explication{margin-top:.5rem}.form-label-small{align-items:center;color:#7f8c8d;color:var(--gray-color);display:flex;font-size:.875rem;font-weight:500;gap:.5rem;margin-bottom:.5rem}.form-label-small i{color:#3498db;color:var(--info-color)}.explication-textarea{font-size:.875rem;line-height:1.4;min-height:60px;resize:vertical}.correct-answer-radio{margin:0}.correct-answer-label{color:#28a745;cursor:pointer;font-size:.9rem;font-weight:500;margin:0}.form-actions{border-top:1px solid #eee;display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem;padding-top:1.5rem}.button-spinner{border:2px solid #0000;border-top-color:currentcolor;height:16px;margin-right:.5rem;width:16px}@media (max-width:768px){.option-input-group{padding:.75rem}.option-main{align-items:stretch;flex-direction:column;gap:.5rem}.option-actions{justify-content:space-between}.form-actions{flex-direction:column}.header{padding:.5rem .75rem}.header-actions{flex-direction:column;gap:.3rem}.teacher-info{align-items:center;margin-bottom:.15rem;margin-right:0;padding:0}.teacher-name{font-size:.65rem}.teacher-stats{font-size:.5rem}.header .logo{font-size:1rem}.header .btn{font-size:.75rem;padding:.3rem .5rem}}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-background{height:100%;left:0;position:absolute;top:0;width:100%;z-index:1}.login-shapes{height:100%;position:relative;width:100%}.shape{animation:float 6s ease-in-out infinite;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border-radius:50%;position:absolute}.shape-1{animation-delay:0s;height:200px;left:10%;top:10%;width:200px}.shape-2{animation-delay:2s;height:150px;right:15%;top:60%;width:150px}.shape-3{animation-delay:4s;bottom:20%;height:100px;left:20%;width:100px}@keyframes float{0%,to{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-20px) rotate(180deg)}}.login-content{max-width:450px;padding:2rem;position:relative;width:100%;z-index:2}.login-card{animation:slideUp .8s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:24px;box-shadow:0 20px 40px #0000001a;padding:3rem 2.5rem}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:2.5rem;text-align:center}.login-icon{margin-bottom:1.5rem}.icon-circle{align-items:center;border-radius:50%;box-shadow:0 10px 30px #0003;color:#fff;display:flex;font-size:2rem;height:80px;justify-content:center;margin:0 auto;width:80px}.icon-circle.primary{background:linear-gradient(135deg,#667eea,#764ba2)}.icon-circle.success{background:linear-gradient(135deg,#4facfe,#00f2fe)}.login-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:2rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:#718096;font-size:1rem;margin:0}.login-form{margin-bottom:2rem}.form-group{margin-bottom:1.5rem}.form-label{align-items:center;color:#2d3748;display:flex;font-size:.9rem;font-weight:600;gap:.5rem;margin-bottom:.75rem}.form-label i{color:#667eea;width:16px}.required{color:#e53e3e;font-weight:700}.optional{color:#a0aec0;font-size:.8rem;font-weight:400}.form-input{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border:2px solid #e2e8f0;border-radius:12px;font-size:1rem;padding:1rem 1.25rem;transition:all .3s ease;width:100%}.form-input:focus{background:#fff;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.form-input:disabled{cursor:not-allowed;opacity:.6}.form-hint{color:#a0aec0;font-size:.8rem;line-height:1.4;margin-top:.5rem}.error-message{background:#fed7d7;border:1px solid #feb2b2;border-radius:12px;color:#c53030;font-size:.9rem;gap:.5rem;margin-bottom:1.5rem;padding:1rem}.error-message,.login-button{align-items:center;display:flex}.login-button{background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:12px;box-shadow:0 10px 30px #667eea4d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;gap:.75rem;justify-content:center;padding:1rem 2rem;transition:all .3s ease;width:100%}.login-button:hover:not(:disabled){box-shadow:0 15px 40px #667eea66;transform:translateY(-2px)}.login-button:disabled{cursor:not-allowed;opacity:.7;transform:none}.button-spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:20px;width:20px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.login-footer{text-align:center}.info-message{align-items:center;background:#667eea1a;border-radius:12px;color:#4a5568;display:flex;font-size:.9rem;gap:.5rem;justify-content:center;line-height:1.4;margin-bottom:1.5rem;padding:1rem}.back-button,.info-message i{color:#667eea}.back-button{align-items:center;background:#0000;border:2px solid #667eea;border-radius:12px;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;transition:all .3s ease}.back-button:hover{background:#667eea;color:#fff;transform:translateY(-1px)}.welcome-card{animation:slideUp .8s ease-out;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#fffffff2;border:1px solid #fff3;border-radius:24px;box-shadow:0 20px 40px #0000001a;padding:3rem 2.5rem;text-align:center}.welcome-icon{margin-bottom:2rem}.welcome-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#4facfe,#00f2fe);-webkit-background-clip:text;background-clip:text;color:#2d3748;font-size:2.5rem;font-weight:700;margin-bottom:1rem}.welcome-text{color:#718096;font-size:1.1rem;line-height:1.6;margin-bottom:2rem}.teacher-info{background:#4facfe1a;border:1px solid #4facfe33;border-radius:16px;margin-bottom:2rem;padding:1rem}.teacher-label{color:#4a5568;display:block;font-size:.9rem;font-weight:600;margin-bottom:.5rem}.teacher-name{color:#2d3748;font-size:1.3rem;font-weight:700}.redirect-message{align-items:center;color:#4a5568;display:flex;font-size:1rem;gap:1rem;justify-content:center}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #4facfe4d;border-radius:50%;border-top-color:#4facfe;height:24px;width:24px}@media (max-width:768px){.login-content{padding:1rem}.login-card,.welcome-card{padding:2rem 1.5rem}.login-title,.welcome-title{font-size:1.8rem}.icon-circle{font-size:1.5rem;height:60px;width:60px}.shape-1,.shape-2,.shape-3{display:none}}.question-responses{background:#f8f9fa80;border:1px solid #0000001a;border-radius:8px;margin-top:1rem;padding:1rem}.question-responses h5{color:#495057;font-size:.9rem;font-weight:600;margin:0 0 1rem}.responses-list{display:flex;flex-direction:column;gap:.75rem}.response-item{background:#fff;border:1px solid #0000000d;border-radius:6px;box-shadow:0 1px 3px #0000001a;padding:.75rem}.response-header{justify-content:space-between;margin-bottom:.5rem}.student-name{color:#495057;font-size:.85rem;font-weight:600}.response-meta{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.response-time{color:#6c757d;font-size:.75rem}.modification-count{background:#ffc1071a;border-radius:3px;color:#ffc107;font-size:.7rem;font-weight:500;padding:.2rem .4rem}.response-answer{margin-top:.5rem}.answer-badge{border-radius:4px;display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .5rem}.answer-badge.correct{background:#28a7451a;border:1px solid #28a74533;color:#28a745}.answer-badge.incorrect{background:#dc35451a;border:1px solid #dc354533;color:#dc3545}.answer-badge.warning{background:#ffc1071a;border:1px solid #ffc10733;color:#856404}.answer-text{background:#f8f9facc;border:1px solid #0000000d;color:#495057;display:block;font-size:.9rem;padding:.5rem;white-space:pre-wrap}.question-item{position:relative;transition:all .3s ease}.question-item.question-active{background:linear-gradient(135deg,#28a7450d,#28a74505);border:2px solid #28a745;box-shadow:0 4px 12px #28a74533}.question-title-row{align-items:center;display:flex;gap:1rem;justify-content:space-between}.active-indicator{animation:pulse 2s infinite;background:linear-gradient(135deg,#dc3545,#c82333);border-radius:20px;box-shadow:0 2px 8px #dc35454d;color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.5px;padding:.25rem .75rem;text-transform:uppercase}@keyframes pulse{0%{box-shadow:0 2px 8px #dc35454d;transform:scale(1)}50%{box-shadow:0 4px 16px #dc354566;transform:scale(1.05)}to{box-shadow:0 2px 8px #dc35454d;transform:scale(1)}}@media (max-width:768px){.question-title-row{align-items:flex-start;flex-direction:column;gap:.5rem}.active-indicator{font-size:.7rem;padding:.2rem .6rem}}.response-histogram{margin-top:1rem}.histogram-stats{background:#f8f9fa80;border:1px solid #0000001a;border-radius:8px;display:flex;gap:2rem;margin-bottom:1.5rem;padding:1rem}.stat-item{align-items:center;display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;font-weight:500}.stat-value{color:#495057;font-size:1.2rem}.stat-value.incorrect{color:#dc3545}.histogram-bars{display:flex;flex-direction:column;gap:1rem}.histogram-bar-container{align-items:center;display:flex;gap:1rem}.histogram-label{color:#495057;font-size:.9rem;font-weight:500;min-width:150px;text-align:right}.histogram-bar{background:#0000000d;flex:1 1;height:30px;overflow:hidden}.histogram-bar,.histogram-bar-fill{border-radius:15px;position:relative}.histogram-bar-fill{align-items:center;background:linear-gradient(90deg,#007bff,#0056b3);display:flex;height:100%;justify-content:center;transition:width .3s ease}.histogram-count{color:#fff;font-size:.8rem;font-weight:600;text-shadow:0 1px 2px #0000004d}.histogram-bar-container:first-child .histogram-bar-fill{background:linear-gradient(90deg,#007bff,#0056b3)}.histogram-bar-container:nth-child(2) .histogram-bar-fill{background:linear-gradient(90deg,#28a745,#1e7e34)}.histogram-bar-container:nth-child(3) .histogram-bar-fill{background:linear-gradient(90deg,#ffc107,#e0a800)}.histogram-bar-container:nth-child(4) .histogram-bar-fill{background:linear-gradient(90deg,#dc3545,#c82333)}.histogram-bar-container:nth-child(5) .histogram-bar-fill{background:linear-gradient(90deg,#6f42c1,#5a32a3)}@media (max-width:768px){.histogram-stats{flex-direction:column;gap:1rem}.histogram-bar-container{align-items:stretch;flex-direction:column;gap:.5rem}.histogram-label{min-width:auto;text-align:left}}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:1rem;position:fixed;right:0;top:0;z-index:1000}.modal{animation:modalSlideIn .3s ease-out;background:#fff;border-radius:8px;border-radius:var(--border-radius);box-shadow:0 2px 10px #0000001a;box-shadow:var(--box-shadow);max-height:90vh;max-width:600px;overflow-y:auto;width:100%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:1.5rem}.modal-header-actions{align-items:center;display:flex;gap:1rem}.modal-header h3{color:#2c3e50;color:var(--dark-color);font-size:1.25rem;margin:0}.btn-close{align-items:center;background:none;border:none;border-radius:50%;color:#7f8c8d;color:var(--gray-color);cursor:pointer;display:flex;font-size:1.5rem;height:30px;justify-content:center;padding:0;transition:all .3s ease;transition:var(--transition);width:30px}.btn-close:hover{background-color:#f8f9fa;color:#e74c3c;color:var(--danger-color)}.btn-close:disabled{cursor:not-allowed;opacity:.5}.modal-content{padding:1.5rem}.modal-actions{border-top:1px solid #e9ecef;display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem}.modal-actions .btn{min-width:120px}.form-help{color:#7f8c8d;color:var(--gray-color);display:block;font-size:.875rem;margin-top:.25rem}@media (max-width:768px){.modal{margin:.5rem;max-height:95vh}.modal-actions,.modal-content,.modal-header{padding:1rem}.modal-header{align-items:flex-start;flex-direction:column;gap:1rem}.modal-header-actions{justify-content:space-between;width:100%}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.rating-container{margin:1rem 0}.rating-scale{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem}.rating-labels{color:#6c757d;display:flex;font-size:.9rem;justify-content:space-between;margin-bottom:1rem}.rating-buttons{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.rating-option{align-items:center;cursor:pointer;display:flex}.rating-value{transition:all .2s ease;-webkit-user-select:none;user-select:none}.rating-value:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.rating-display{margin:.5rem 0}.rating-badge{font-weight:500;text-align:center}.rating-config{background:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;padding:1rem}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr;margin-bottom:1rem}.rating-label-input{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.rating-label-input .form-label{font-weight:500;margin:0}@media (max-width:768px){.rating-buttons{justify-content:flex-start}.rating-value{min-width:50px;padding:.4rem .8rem}.form-row{grid-template-columns:1fr}.rating-label-input{align-items:flex-start;flex-direction:column}}.student-ranking{background:#fff;border-radius:10px;box-shadow:none;margin:0;padding:0}.ranking-summary{background:#f8f9fa;border-radius:8px;margin-bottom:20px;padding:15px}.summary-stats{display:flex;flex-wrap:wrap;gap:20px;justify-content:space-around}.summary-item{text-align:center}.summary-label{color:#6c757d;display:block;font-size:.9rem;margin-bottom:5px}.summary-value{color:#2c3e50;display:block;font-size:1.2rem;font-weight:700}.ranking-list{display:flex;flex-direction:column;gap:15px}.ranking-item{align-items:center;background:#fff;border:2px solid #e9ecef;border-radius:10px;display:flex;padding:15px;position:relative;transition:all .3s ease}.ranking-item:hover{border-color:#007bff;box-shadow:0 4px 15px #007bff1a;transform:translateY(-2px)}.rank-badge{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.2rem;font-weight:700;height:50px;justify-content:center;margin-right:15px;width:50px}.student-info{flex:1 1;margin-right:20px}.student-name{color:#2c3e50;font-size:1.1rem;font-weight:700;margin-bottom:5px}.student-id{color:#6c757d;font-size:.9rem}.student-stats{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(2,1fr);margin-right:20px;min-width:200px}.stat-row{align-items:center;display:flex;justify-content:space-between}.stat-label{color:#6c757d;font-size:.85rem}.stat-value{font-size:.9rem;font-weight:700}.stat-value.correct,.stat-value.success{color:#28a745}.performance-bar{background-color:#e9ecef;border-radius:4px;flex-shrink:0;height:8px;overflow:hidden;width:100px}.performance-fill{border-radius:4px;height:100%;transition:width .3s ease}.ranking-legend{background:#f8f9fa;border-left:4px solid #007bff;border-radius:8px;margin-top:25px;padding:15px}.ranking-legend h4{color:#2c3e50;font-size:1rem;margin:0 0 10px}.ranking-legend ul{margin:0;padding-left:20px}.ranking-legend li{color:#495057;font-size:.9rem;margin-bottom:5px}.no-data{color:#6c757d;padding:40px;text-align:center}@media (max-width:768px){.ranking-item{align-items:flex-start;flex-direction:column;gap:15px}.rank-badge{align-self:center;margin-right:0}.student-info{margin-right:0;text-align:center;width:100%}.student-stats{grid-template-columns:1fr;margin-right:0;width:100%}.performance-bar{width:100%}.summary-stats{flex-direction:column;gap:10px}}.ranking-modal{max-height:90vh;max-width:900px;width:95%}.ranking-modal .modal-content{max-height:calc(90vh - 120px);overflow-y:auto;padding:0}.ranking-modal .student-ranking{padding:20px}.stats-modal{max-height:90vh;max-width:1000px;width:95%}.stats-modal .modal-content{max-height:calc(90vh - 120px);overflow-y:auto;padding:0}.stats-modal .session-statistics{margin:0;padding:20px}@media (max-width:768px){.ranking-modal{margin:.5rem;max-width:95%;width:95%}.ranking-modal .modal-content{max-height:calc(90vh - 100px)}.ranking-modal .student-ranking{padding:15px}.stats-modal{margin:.5rem;max-width:95%;width:95%}.stats-modal .modal-content{max-height:calc(90vh - 100px)}.stats-modal .session-statistics{padding:15px}}.explanation-section{background-color:#f8f9fa;border-left:4px solid #3498db;border-left:4px solid var(--info-color);border-radius:4px;margin-top:1rem;padding:1rem}.explanation-section p{margin-bottom:.5rem}.explanation-text{color:#6c757d;font-style:italic;line-height:1.5}.suggested-answer-section{background-color:#e8f5e8;border-left:4px solid #2ecc71;border-left:4px solid var(--success-color);border-radius:4px;margin-top:1rem;padding:1rem}.suggested-answer-section p{margin-bottom:.5rem}.suggested-answer-text{color:#2e7d32;font-style:italic;line-height:1.5}.open-ended-evaluation{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:1.5rem;padding:1rem}.evaluation-status{background-color:#fff;border:1px solid #dee2e6;border-radius:6px;margin-bottom:1rem;padding:.75rem}.evaluation-status.status-active{background-color:#d4edda;border-color:#c3e6cb}.evaluation-status.status-created{background-color:#f8d7da;border-color:#f5c6cb}.status-message{color:#6c757d;font-size:.875rem;margin:.5rem 0 0}.concordance-evaluation{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-top:1rem;padding:1rem}.score-display{align-items:center;display:flex;gap:.75rem;margin:.5rem 0}.score-badge{align-items:center;border-radius:16px;color:#fff;display:inline-flex;font-size:.875rem;font-weight:600;height:32px;justify-content:center;min-width:60px;padding:0 .75rem}.score-badge.score-excellent{background-color:#28a745}.score-badge.score-good{background-color:#17a2b8}.score-badge.score-average{background-color:#ffc107;color:#212529}.score-badge.score-poor{background-color:#dc3545}.score-label{color:#495057;font-weight:500}.ai-feedback{background-color:#fff;border-left:4px solid #007bff;margin-top:1rem}.feedback-text{font-style:italic}.evaluation-time{margin:.5rem 0 0}@media (max-width:768px){.stats-summary{gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.score-display{align-items:flex-start;flex-direction:column;gap:.5rem}.evaluation-actions .btn{padding:.875rem 1rem;width:100%}}.evaluation-actions .btn:disabled{cursor:not-allowed;opacity:.7}.score-distribution .distribution-item{margin-bottom:.75rem}.score-distribution .distribution-fill{transition:width .3s ease-in-out}.unevaluated-indicator{align-items:center;background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:4px;color:#856404;display:inline-flex;font-size:.75rem;gap:.5rem;padding:.25rem .5rem}.unevaluated-indicator:before{content:"⚠️";font-size:.875rem}.stat-subtitle{color:#6c757d;font-size:.75rem;line-height:1.2;margin-top:.25rem}.status-badge.status-active{background-color:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-badge.status-info{background-color:#d1ecf1;border:1px solid #bee5eb;color:#0c5460}.status-badge.status-created{background-color:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.stats-grid .stat-item{position:relative}.stats-grid .stat-item .stat-subtitle{border-top:1px solid #e9ecef;margin-top:.5rem;padding-top:.25rem}.open-ended-stats{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:6px;margin-top:1rem;padding:1rem}.open-ended-stats h6{color:#495057;font-weight:600;margin-bottom:.75rem}.concordance-indicator{align-items:center;border-radius:12px;display:inline-flex;font-size:.75rem;font-weight:600;gap:.5rem;padding:.25rem .75rem}.concordance-indicator.excellent{background-color:#d4edda;color:#155724}.concordance-indicator.good{background-color:#d1ecf1;color:#0c5460}.concordance-indicator.average{background-color:#fff3cd;color:#856404}.concordance-indicator.poor{background-color:#f8d7da;color:#721c24}.open-ended-evaluations{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:1.5rem;padding:1rem}.evaluations-list{margin-top:1rem}.evaluation-item{background-color:#fff;border:1px solid #dee2e6;border-radius:6px;margin-bottom:1rem;padding:1rem}.evaluation-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:.75rem;padding-bottom:.5rem}.student-info{align-items:center;display:flex;gap:.75rem}.evaluation-meta{color:#6c757d;font-size:.875rem}.evaluation-content{margin-top:.75rem}.unevaluated-responses{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;margin-top:1.5rem;padding:1rem}.unevaluated-list{margin-top:.75rem}.unevaluated-item{background-color:#fff;border:1px solid #ffeaa7;border-radius:4px;margin-bottom:.5rem;padding:.75rem}.unevaluated-item .student-info{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem}@media (max-width:768px){.evaluation-header,.student-info{align-items:flex-start;flex-direction:column;gap:.5rem}.evaluation-meta{align-self:flex-end}}.open-ended-evaluation-section{background-color:#f8f9fa;border:1px solid #e9ecef;border-radius:8px;margin-top:1rem;padding:1rem}.open-ended-evaluation-section h6{color:#495057;font-weight:600;margin-bottom:1rem}.open-ended-response{margin-bottom:1rem}.evaluated-response,.unevaluated-response{background-color:#fff;border:1px solid #dee2e6;border-radius:6px;margin-bottom:.75rem;padding:1rem}.response-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;gap:.75rem;margin-bottom:.75rem;padding-bottom:.5rem}.response-content{margin-top:.75rem}.student-answer{margin-bottom:1rem}.answer-text{background-color:#f8f9fa;border-left:4px solid #007bff;font-style:italic;line-height:1.5;margin:.5rem 0 0}.ai-feedback,.answer-text{border-radius:4px;padding:.75rem}.ai-feedback{background-color:#e7f3ff;border-left:4px solid #17a2b8}.feedback-text{color:#495057;line-height:1.5;margin:.5rem 0 0}.evaluation-time{color:#6c757d;font-size:.75rem;margin-top:.5rem}.evaluation-stats{margin-top:1rem}.stats-summary{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:1.5rem}.score-distribution{margin-top:1.5rem}.score-distribution h6{color:#495057;margin-bottom:1rem}.evaluation-actions{margin-top:1.5rem;text-align:center}.evaluation-actions .btn{font-weight:500;padding:.75rem 1.5rem}@media (max-width:768px){.stats-summary{gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.response-header{align-items:flex-start;flex-direction:column;gap:.5rem}.evaluation-actions .btn{padding:.875rem 1rem;width:100%}}
/*# sourceMappingURL=main.65fa6c11.css.map*/