.login-page{min-height:100vh;display:flex;background:#fff;overflow:hidden}.login-image-section{flex:1;position:relative;background:linear-gradient(135deg,#f0f4f8,#e8f5e9);display:flex;align-items:center;justify-content:center;padding:40px}.login-image-wrapper{width:100%;max-width:600px;position:relative}.login-image-wrapper img{width:100%;height:auto;border-radius:24px;box-shadow:0 20px 60px #00000026}.login-overlay-text{position:absolute;bottom:40px;left:40px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.3)}.login-overlay-text h2{font-size:32px;font-weight:700;margin-bottom:8px}.login-overlay-text p{font-size:16px;opacity:.95}.login-form-section{flex:1;display:flex;align-items:center;justify-content:center;padding:40px;background:#fff}.login-container{width:100%;max-width:480px;padding:20px}.login-logo{text-align:center;margin-bottom:40px}.login-logo img{max-width:280px;height:auto;margin-bottom:16px}.login-tagline{color:var(--text-secondary);font-size:14px;font-weight:500;letter-spacing:.3px;display:none}.login-welcome{text-align:center;margin-bottom:36px}.login-title{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.login-subtitle{color:var(--text-secondary);font-size:15px;line-height:1.5}.login-tabs{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:32px;padding:6px;background:var(--bg-accent);border-radius:12px}.login-tab{padding:14px;border:none;background:transparent;color:var(--text-secondary);font-weight:600;font-size:15px;border-radius:8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.login-tab:hover{color:var(--primary);background:#fff}.login-tab.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #7fb53940}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input{padding:14px 16px;background:var(--bg-accent);border:1px solid var(--border-light);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all .3s ease}.form-group input::placeholder{color:var(--text-muted)}.form-options{display:flex;justify-content:space-between;align-items:center;margin-top:-8px}.remember-me{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.remember-me input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--primary)}.forgot-password{font-size:14px;color:var(--primary);text-decoration:none;font-weight:600;cursor:pointer}.forgot-password:hover{text-decoration:underline}.btn-login{padding:16px;background:var(--primary);border:none;border-radius:10px;color:#fff;font-size:16px;font-weight:700;cursor:pointer;margin-top:8px;transition:all .3s ease;box-shadow:0 4px 12px #7fb53940}.btn-login:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:0 6px 16px #7fb5394d}.btn-login:active{transform:translateY(0)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.error{background:#ffebee;border:1px solid #EF9A9A;color:#c62828;padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:20px;display:flex;align-items:center;gap:8px}.success{background:#e8f5e9;border:1px solid #A5D6A7;color:#2e7d32;padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:20px}.decorative-circle{position:absolute;border-radius:50%;opacity:.1;pointer-events:none}.decorative-circle-1{width:400px;height:400px;background:var(--primary);top:-200px;right:-200px}.decorative-circle-2{width:300px;height:300px;background:var(--primary-light);bottom:-150px;left:-150px}@media(max-width:1024px){.login-page{flex-direction:column}.login-image-section{min-height:40vh}.login-form-section{min-height:60vh}}@media(max-width:768px){.login-image-section{padding:20px;min-height:30vh}.login-form-section{padding:20px}.login-container{padding:10px}.login-logo img{max-width:220px}.login-title{font-size:24px}.login-overlay-text{bottom:20px;left:20px}.login-overlay-text h2{font-size:24px}.login-overlay-text p{font-size:14px}}.sidebar{width:280px;height:100vh;background:#fff;border-right:1px solid var(--border-light);display:flex;flex-direction:column;position:fixed;left:0;top:0;overflow-y:auto;z-index:1000}.sidebar-logo{padding:24px 20px;border-bottom:1px solid var(--border-light);text-align:center}.sidebar-logo img{max-width:180px;height:auto}.sidebar-icon{width:60px;height:auto;display:block;margin:0 auto 12px;filter:drop-shadow(0 2px 8px rgba(76,175,80,.3));transition:transform .3s ease}.sidebar-icon:hover{transform:scale(1.05)}.sidebar-brand{font-size:16px;font-weight:700;color:var(--primary);text-align:center;letter-spacing:.5px;margin-top:8px}.sidebar-nav{flex:1;padding:20px 16px;display:flex;flex-direction:column;gap:24px;overflow-y:auto}.nav-section{display:flex;flex-direction:column;gap:4px}.nav-section-bottom{margin-top:auto}.nav-section-title{font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:1px;padding:12px 12px 8px;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border:none;background:transparent;border-radius:10px;cursor:pointer;transition:all .3s ease;text-align:left;width:100%;position:relative}.nav-item:hover:not(:disabled){background:var(--bg-accent);color:var(--primary)}.nav-item.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px #7fb53940}.nav-item:disabled{opacity:.5;cursor:not-allowed}.nav-icon{font-size:20px;flex-shrink:0}.nav-label{font-size:15px;font-weight:600;flex:1;color:var(--text-primary)}.nav-item.active .nav-label,.nav-item.active .nav-icon{color:#fff}.nav-item:hover:not(:disabled) .nav-label{color:var(--primary)}.nav-badge{padding:4px 8px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.badge-soon{background:#fff9e6;color:#f57c00;border:1px solid #FFE082}.badge-new{background:#e8f5e9;color:#2e7d32;border:1px solid #A5D6A7}.nav-item-logout{color:var(--danger)}.nav-item-logout:hover{background:#ffebee;color:var(--danger)}.nav-item-logout .nav-label{color:var(--danger)}.sidebar-user{padding:20px;border-top:1px solid var(--border-light);display:flex;align-items:center;gap:12px;background:var(--bg-accent)}.user-avatar{width:48px;height:48px;background:var(--gradient-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.user-info{flex:1;min-width:0}.user-name{font-size:15px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-transform:capitalize}.user-role{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:var(--bg-accent)}.sidebar::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--primary)}@media(max-width:768px){.sidebar{width:100%;height:auto;position:relative;border-right:none;border-bottom:1px solid var(--border-light)}.sidebar-nav{flex-direction:row;overflow-x:auto;padding:12px}.nav-section{flex-direction:row}.nav-section-title,.nav-label{display:none}.nav-item{padding:12px;justify-content:center}.sidebar-user{padding:12px}}.admin-dashboard{min-height:100vh;background:var(--bg-primary);display:flex}.dashboard-container{max-width:1600px;margin:0 auto}.dashboard-header{background:#fff;border-radius:12px;padding:28px 40px;margin-bottom:32px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center}.dashboard-header-left h1{font-size:26px;font-weight:700;margin-bottom:6px;color:var(--text-primary)}.dashboard-header-left p{color:var(--text-secondary);font-size:14px}.dashboard-header-actions{display:flex;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;border-radius:12px;display:flex;align-items:center;gap:16px;padding:28px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--gradient-primary)}.stat-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.stat-card-title{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-card-icon{width:48px;height:48px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px}.stat-card-value{font-size:36px;font-weight:700;color:var(--primary);margin-bottom:8px}.stat-card-label{font-size:13px;color:var(--text-secondary)}.action-buttons{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:32px}.action-btn{background:#fff;border:1px solid var(--border-light);border-radius:12px;padding:24px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:16px;text-align:left;box-shadow:var(--shadow-sm)}.action-btn:hover{background:var(--bg-accent);border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-btn-icon{width:48px;height:48px;background:var(--gradient-primary);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.action-btn-content h3{font-size:16px;font-weight:600;margin-bottom:4px;color:var(--text-primary)}.action-btn-content p{font-size:13px;color:var(--text-secondary)}.add-student-section,.upload-section,.students-section{background:#fff;border-radius:12px;padding:32px;margin-bottom:24px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.add-student-section h2,.upload-section h2,.students-section h2{font-size:18px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:12px;color:var(--text-primary);padding-bottom:16px;border-bottom:2px solid var(--border-light)}.section-icon{width:32px;height:32px;background:var(--gradient-primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}.form-row{display:flex;gap:12px;align-items:flex-end}.form-group{flex:1}.form-group label{display:block;font-size:14px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.form-group input{width:100%;padding:12px 16px;background:var(--bg-accent);border:1px solid var(--border-light);border-radius:8px;color:var(--text-primary);font-size:15px;transition:all .3s ease}.form-group input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #7fb5391a}.btn{padding:12px 24px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:14px;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:#fff;color:var(--text-primary);border:1px solid var(--border-medium)}.btn-danger{background:var(--danger);color:#fff;box-shadow:var(--shadow-sm)}.btn-danger:hover{background:#c82333;transform:translateY(-1px);box-shadow:var(--shadow-md)}.students-table{width:100%;border-collapse:collapse;border-radius:10px;overflow:hidden}.status-badge.completed{background:#e8f5e9;color:#2e7d32;border:1px solid #A5D6A7}.status-badge.not-completed{background:#fff9e6;color:#f57c00;border:1px solid #FFE082}.pass-fail-badge.pass{background:#e8f5e9;color:#2e7d32;border:1px solid #A5D6A7}.pass-fail-badge.fail{background:#ffebee;color:#c62828;border:1px solid #EF9A9A}.file-input-wrapper{position:relative;display:inline-block}.file-input-wrapper input[type=file]{position:absolute;opacity:0;width:0;height:0}.file-input-label{display:inline-flex;align-items:center;gap:10px;padding:12px 24px;background:#fff;border:2px dashed var(--border-medium);border-radius:8px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .3s ease}.file-input-label:hover{border-color:var(--primary);background:var(--bg-accent)}.success-message{background:#e8f5e9;border:1px solid #A5D6A7;color:#2e7d32;padding:12px 16px;border-radius:8px;margin-top:12px;font-size:14px}.error-message{background:#ffebee;border:1px solid #EF9A9A;color:#c62828;padding:12px 16px;border-radius:8px;margin-top:12px;font-size:14px}.quiz-reports-section{margin-top:40px}.quiz-reports-section>h2{font-size:22px;font-weight:700;color:var(--text-primary);margin-bottom:24px}.quiz-report-card{background:#fff;border-radius:12px;padding:28px;margin-bottom:24px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.quiz-report-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border-light)}.quiz-report-header h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:6px}.quiz-report-header p{color:var(--text-secondary);font-size:14px;margin:0}.quiz-report-stats{display:flex;gap:20px}.stat-small{padding:8px 16px;background:var(--bg-accent);border-radius:8px;font-size:14px;color:var(--text-secondary)}.stat-small strong{color:var(--primary);font-size:18px}.mini-results-table{margin-top:16px}.no-reports{text-align:center;padding:60px 20px;background:#fff;border-radius:12px;border:1px solid var(--border-light);color:var(--text-secondary)}@media(max-width:768px){.dashboard-main{margin-left:0;padding:80px 16px 16px}.dashboard-header{flex-direction:column;gap:16px;text-align:center;padding:20px}.stats-grid{grid-template-columns:1fr}.form-row{flex-direction:column}}.stat-icon{font-size:36px;line-height:1}.stat-info{flex:1}.stat-info h3{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.stat-primary{border-left:4px solid #4CAF50}.stat-success{border-left:4px solid #2E7D32}.stat-info{border-left:4px solid #1976D2}.stat-warning{border-left:4px solid #F57C00}.leaderboard-card{margin-bottom:32px}.leaderboard-card h2{font-size:22px;font-weight:700;margin-bottom:24px;color:var(--text-primary)}.leaderboard-container{overflow-x:auto}.leaderboard-table{width:100%;border-collapse:separate;border-spacing:0}.leaderboard-table thead th{background:var(--bg-accent);padding:16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-light)}.leaderboard-table tbody tr{transition:all .2s ease}.leaderboard-table tbody tr:hover{background:var(--bg-accent);transform:translate(4px)}.leaderboard-table tbody td{padding:16px;border-bottom:1px solid var(--border-light)}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:50%;background:var(--bg-accent);font-weight:700;color:var(--text-primary)}.rank-gold .rank-badge{background:linear-gradient(135deg,gold,orange);color:#fff;box-shadow:0 4px 12px #ffd70066}.rank-silver .rank-badge{background:linear-gradient(135deg,silver,#a8a8a8);color:#fff;box-shadow:0 4px 12px #c0c0c066}.rank-bronze .rank-badge{background:linear-gradient(135deg,#cd7f32,#b87333);color:#fff;box-shadow:0 4px 12px #cd7f3266}.student-cell{display:flex;flex-direction:column;gap:4px}.student-cell strong{color:var(--text-primary);font-size:15px}.student-cell small{color:var(--text-secondary);font-size:12px}.percentage-bar{position:relative;width:120px;height:32px;background:var(--bg-accent);border-radius:8px;overflow:hidden}.percentage-fill{position:absolute;left:0;top:0;height:100%;background:linear-gradient(90deg,var(--primary),#66BB6A);transition:width .5s ease}.percentage-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);font-weight:700;color:var(--text-primary);font-size:13px;z-index:1}.badge-pill{display:inline-block;padding:6px 12px;border-radius:16px;font-size:12px;font-weight:600}.badge-success{background:#e8f5e9;color:#2e7d32}.badge-warning{background:#fff3e0;color:#f57c00}.trophy-badge{font-size:24px}.create-quiz-page{min-height:100vh;background:var(--bg-primary);padding:20px}.create-quiz-container{max-width:1200px;margin:0 auto}.quiz-header{background:var(--bg-card);border-radius:20px;padding:30px 40px;margin-bottom:30px;border:1px solid rgba(139,92,246,.2);display:flex;justify-content:space-between;align-items:center}.quiz-header h1{font-size:32px;font-weight:700;color:var(--text-primary)}.quiz-card{background:var(--bg-card);border-radius:20px;padding:32px;border:1px solid rgba(139,92,246,.2);margin-bottom:24px}.quiz-card h2{font-size:20px;font-weight:700;margin-bottom:24px;display:flex;align-items:center;gap:12px}.form-group label{display:block;margin-bottom:10px;font-weight:600;color:var(--text-primary);font-size:14px}.form-group input[type=text],.form-group input[type=password],.form-group input[type=date],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:14px 16px;background:var(--bg-secondary);border:1px solid rgba(139,92,246,.3);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all .3s ease}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #8b5cf61a}.form-group textarea{font-family:inherit;resize:vertical;min-height:120px}.form-group small{display:block;margin-top:8px;color:var(--text-secondary);font-size:13px}.form-group input[type=range]{width:100%;margin-top:10px;accent-color:var(--primary)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.range-value{display:inline-block;margin-left:12px;padding:4px 12px;background:var(--gradient-primary);color:#fff;border-radius:6px;font-weight:600;font-size:14px}.questions-preview{display:flex;flex-direction:column;gap:20px}.question-preview-card{background:var(--bg-secondary);border:1px solid rgba(139,92,246,.2);border-radius:14px;padding:24px;transition:all .3s ease}.question-preview-card:hover{border-color:var(--primary);box-shadow:0 4px 16px #8b5cf61a}.question-preview-card .question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.question-preview-card h3{margin:0;color:var(--text-primary);font-size:16px;font-weight:600}.question-preview-card .question-text{color:var(--text-primary);margin-bottom:16px;line-height:1.6}.question-preview-card .options{display:flex;flex-direction:column;gap:10px}.question-preview-card .option{padding:12px;background:var(--bg-card);border:1px solid rgba(139,92,246,.15);border-radius:8px;color:var(--text-secondary);font-size:14px}.question-preview-card .option.correct{border-color:var(--success);background:#10b9810d;color:var(--success)}.btn{padding:14px 24px;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:14px;display:inline-flex;align-items:center;gap:8px}.btn-large{width:100%;padding:16px;font-size:16px;font-weight:700}.btn:disabled{opacity:.6;cursor:not-allowed}.success-message{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success);padding:14px 18px;border-radius:10px;margin-bottom:20px;font-size:14px}.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--danger);padding:14px 18px;border-radius:10px;margin-bottom:20px;font-size:14px}.step-indicator{display:flex;justify-content:center;gap:12px;margin-bottom:30px}.step{width:40px;height:40px;border-radius:50%;background:var(--bg-card);border:2px solid rgba(139,92,246,.3);display:flex;align-items:center;justify-content:center;font-weight:600;color:var(--text-secondary);transition:all .3s ease}.step.active{background:var(--gradient-primary);border-color:transparent;color:#fff;box-shadow:0 4px 12px #8b5cf64d}.step.completed{background:var(--success);border-color:transparent;color:#fff}@media(max-width:768px){.form-row{grid-template-columns:1fr}.quiz-header{flex-direction:column;gap:16px;text-align:center}.quiz-header-actions{width:100%;flex-direction:column}.btn{width:100%;justify-content:center}}.quiz-management-page{min-height:100vh;background:var(--bg-primary);padding:20px}.quiz-management-container{max-width:1400px;margin:0 auto}.management-header{background:var(--bg-card);border-radius:20px;padding:30px 40px;margin-bottom:30px;border:1px solid rgba(139,92,246,.2);display:flex;justify-content:space-between;align-items:center}.management-header h1{font-size:32px;font-weight:700;color:var(--text-primary)}.quiz-management-page{min-height:100vh;background:var(--bg-primary);display:flex}.management-layout{display:grid;grid-template-columns:350px 1fr;gap:24px;margin-top:24px}.quizzes-sidebar{background:#fff;border-radius:12px;padding:24px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);max-height:calc(100vh - 250px);overflow-y:auto;position:sticky;top:24px}.quizzes-sidebar h3{font-size:16px;font-weight:700;color:var(--text-primary);margin-bottom:16px}.quizzes-list-admin{display:flex;flex-direction:column;gap:12px}.quiz-item{padding:16px;background:var(--bg-accent);border-radius:8px;border:2px solid transparent;cursor:pointer;transition:all .3s ease}.quiz-item:hover{border-color:var(--primary);background:#fff}.quiz-item.active{border-color:var(--primary);background:#e8f5e9}.quiz-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:8px}.quiz-item-header strong{color:var(--text-primary);font-size:14px;flex:1}.quiz-date-badge{background:var(--primary);color:#fff;padding:4px 10px;border-radius:6px;font-size:11px;font-weight:600;flex-shrink:0}.quiz-item-meta{font-size:13px;color:var(--text-secondary)}.no-quizzes{text-align:center;padding:40px 20px;color:var(--text-secondary)}.quiz-details-area{display:flex;flex-direction:column;gap:20px}.quiz-details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:16px;font-size:14px;color:var(--text-secondary)}.quiz-details-grid strong{color:var(--text-primary)}.no-selection{text-align:center;padding:80px 20px;color:var(--text-secondary)}.date-picker-section{background:var(--bg-card);border-radius:20px;padding:32px;margin-bottom:30px;border:1px solid rgba(139,92,246,.2)}.date-picker-section h2{font-size:20px;font-weight:700;margin-bottom:20px}.quiz-info-card{background:var(--bg-card);border-radius:20px;padding:32px;margin-bottom:30px;border:1px solid rgba(139,92,246,.2)}.quiz-info-card h2{font-size:24px;font-weight:700;margin-bottom:12px}.quiz-info-card p{color:var(--text-secondary);margin-bottom:20px;line-height:1.6}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-secondary);border-radius:16px;padding:24px;border:1px solid rgba(139,92,246,.15);transition:all .3s ease}.stat-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:0 8px 24px #8b5cf633}.results-section{background:var(--bg-card);border-radius:20px;padding:32px;margin-bottom:30px;border:1px solid rgba(139,92,246,.2)}.results-section h3{font-size:18px;font-weight:700;margin-bottom:20px}.results-table{width:100%;border-collapse:collapse}.results-table thead{background:var(--bg-secondary)}.results-table th{padding:16px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(139,92,246,.1)}.results-table td{padding:16px;border-bottom:1px solid rgba(139,92,246,.1);color:var(--text-primary)}.results-table tbody tr{transition:all .2s ease}.results-table tbody tr:hover{background:var(--bg-secondary)}.badge-success,.badge-pass{background:#10b9811a;color:var(--success)}.badge-danger,.badge-fail{background:#ef44441a;color:var(--danger)}.badge-warning{background:#f59e0b1a;color:var(--warning)}.no-quiz p{color:var(--text-secondary)}.student-dashboard{min-height:100vh;background:var(--bg-primary);display:flex}.dashboard-main{flex:1;margin-left:280px;padding:24px;min-height:100vh}.dashboard-container{max-width:1400px;margin:0 auto}.dashboard-header{background:#fff;border-radius:12px;padding:32px 40px;margin-bottom:32px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{font-size:28px;font-weight:700;margin-bottom:6px;color:var(--text-primary)}.dashboard-header p{color:var(--text-secondary);font-size:15px}.header-actions{display:flex;gap:12px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-bottom:32px}.stat-card{background:#fff;border-radius:12px;padding:28px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;display:flex;align-items:center;gap:20px}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.stat-icon{width:64px;height:64px;background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:32px;flex-shrink:0}.stat-content{flex:1}.stat-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-weight:600}.stat-value{font-size:36px;font-weight:700;color:var(--primary)}.content-grid{display:grid;grid-template-columns:1fr 1.3fr;gap:24px}.quiz-card-section,.reports-section{display:flex;flex-direction:column;gap:24px}.section-card{background:#fff;border-radius:12px;padding:32px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.section-header{margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border-light)}.section-header h2{font-size:18px;font-weight:700;color:var(--text-primary);margin:0}.quizzes-list{display:flex;flex-direction:column;gap:16px}.quiz-available{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--bg-accent);border-radius:10px;padding:24px;border:1px solid var(--border-light);transition:all .3s ease}.quiz-available:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.quiz-info h3{font-size:20px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.quiz-info p{color:var(--text-secondary);line-height:1.6;margin-bottom:16px}.quiz-meta{display:flex;flex-wrap:wrap;gap:16px}.meta-item{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary);padding:6px 12px;background:var(--bg-accent);border-radius:6px}.meta-icon{font-size:16px}.btn-start-quiz{width:100%;padding:18px 24px;background:var(--primary);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;gap:8px}.btn-start-quiz:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.no-quiz{text-align:center;padding:48px 24px;background:var(--bg-accent);border-radius:10px}.no-quiz-icon{font-size:64px;margin-bottom:16px;opacity:.4}.no-quiz h3{font-size:18px;font-weight:600;margin-bottom:8px;color:var(--text-primary)}.no-quiz p{color:var(--text-secondary);margin:0}.attendance-placeholder{text-align:center;padding:48px 24px;background:var(--bg-accent);border-radius:10px}.placeholder-icon{font-size:48px;margin-bottom:16px;opacity:.4}.history-table-container{overflow-x:auto;border-radius:10px;border:1px solid var(--border-light)}.history-table{width:100%;border-collapse:collapse}.history-table thead{background:var(--bg-accent)}.history-table th{padding:14px 16px;text-align:left;font-weight:600;color:var(--text-primary);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:14px 16px;border-top:1px solid var(--border-light);color:var(--text-primary);font-size:14px}.history-table tbody tr{transition:all .2s ease}.history-table tbody tr:hover{background:var(--bg-accent)}.btn-view-all{width:100%;padding:12px;background:#fff;color:var(--primary);border:1px solid var(--primary);border-radius:8px;font-weight:600;cursor:pointer;margin-top:16px;transition:all .3s ease}.btn-view-all:hover{background:var(--primary);color:#fff}.no-history{text-align:center;padding:48px 24px;background:var(--bg-accent);border-radius:10px}.no-history-icon{font-size:64px;margin-bottom:16px;opacity:.4}.no-history p{color:var(--text-secondary);margin:0}@media(max-width:1024px){.content-grid{grid-template-columns:1fr}}@media(max-width:768px){.dashboard-main{margin-left:0;padding:80px 16px 16px}.dashboard-header{flex-direction:column;gap:16px;text-align:center;padding:24px}.stats-grid{grid-template-columns:1fr}.stat-card{flex-direction:column;text-align:center}.quick-actions{grid-template-columns:1fr}}.performance-chart{padding:20px 0}.chart-container{display:flex;flex-direction:column;gap:24px}.chart-bars{display:flex;align-items:flex-end;justify-content:space-around;height:300px;gap:12px;padding:20px;background:var(--bg-accent);border-radius:12px;border:1px solid var(--border-light)}.chart-bar-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px}.bar-container{width:100%;height:260px;background:#f0f0f0;border-radius:8px 8px 0 0;position:relative;display:flex;align-items:flex-end}.bar-fill{width:100%;border-radius:8px 8px 0 0;transition:height .5s ease;display:flex;align-items:center;justify-content:center;position:relative}.bar-fill.pass{background:linear-gradient(180deg,#4caf50,#66bb6a)}.bar-fill.fail{background:linear-gradient(180deg,#ef5350,#f44336)}.bar-label{color:#fff;font-size:14px;font-weight:700;position:absolute;top:8px}.bar-info{text-align:center}.bar-date{font-size:12px;color:var(--text-secondary);font-weight:600}.chart-legend{display:flex;justify-content:center;gap:32px}.legend-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.legend-color{width:20px;height:20px;border-radius:4px}.legend-color.pass{background:#4caf50}.legend-color.fail{background:#f44336}.no-data{text-align:center;padding:60px 20px}.no-data-icon{font-size:64px;margin-bottom:16px}.no-data h3{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.no-data p{color:var(--text-secondary);font-size:15px}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.action-btn{display:flex;align-items:center;gap:16px;padding:20px;background:var(--bg-accent);border:2px solid var(--border-light);border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:left}.action-btn:hover{border-color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}.action-icon{font-size:32px;flex-shrink:0}.action-btn div{display:flex;flex-direction:column;gap:4px}.action-btn strong{font-size:16px;color:var(--text-primary)}.action-btn span{font-size:13px;color:var(--text-secondary)}.action-btn.buzz-action{position:relative}.unread-badge{position:absolute;top:10px;right:10px;background:#f44336;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;box-shadow:0 2px 4px #0003}.my-quizzes-page{min-height:100vh;background:var(--bg-primary);display:flex}.page-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0 0 8px}.page-header p{color:var(--text-secondary);font-size:16px;margin:0}.quizzes-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:24px}.quiz-card{background:#fff;border-radius:16px;padding:28px;border:2px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;display:flex;flex-direction:column}.quiz-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--primary)}.quiz-card.expired{opacity:.6;border-color:#ccc}.quiz-card.expired:hover{transform:none;border-color:#ccc}.quiz-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.quiz-card-header h3{font-size:20px;font-weight:700;color:var(--text-primary);margin:0;flex:1;line-height:1.3}.status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;white-space:nowrap}.status-badge.active{background:#e8f5e9;color:#2e7d32}.status-badge.expiring{background:#fff3e0;color:#e65100}.status-badge.expired{background:#ffebee;color:#c62828}.quiz-description{color:var(--text-secondary);font-size:15px;line-height:1.5;margin-bottom:24px;flex:1}.quiz-meta-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:24px;padding:20px;background:var(--bg-accent);border-radius:12px}.meta-item{display:flex;align-items:center;gap:12px}.meta-icon{font-size:24px;flex-shrink:0}.meta-item div{display:flex;flex-direction:column;gap:2px}.meta-item strong{font-size:16px;font-weight:700;color:var(--text-primary)}.meta-item span{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.btn-take-quiz{width:100%;padding:16px;background:linear-gradient(135deg,var(--primary),#4CAF50);color:#000;border:none;border-radius:10px;font-size:16px;font-weight:700;cursor:pointer;transition:all .3s ease}.btn-take-quiz:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #4caf504d}.btn-take-quiz:disabled{background:#e0e0e0;color:#999;cursor:not-allowed}.no-quizzes{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;border:1px solid var(--border-light)}.no-quizzes-icon{font-size:64px;margin-bottom:20px}.no-quizzes h3{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.no-quizzes p{color:var(--text-secondary);font-size:16px}@media(max-width:1024px){.quizzes-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}}@media(max-width:768px){.quizzes-grid,.quiz-meta-grid{grid-template-columns:1fr}}.quiz-page{min-height:100vh;background:var(--bg-primary);display:flex}.quiz-overview-container{max-width:900px;margin:0 auto;padding:40px 20px}.quiz-overview-card{background:#fff;border-radius:16px;padding:48px;border:1px solid var(--border-light);box-shadow:var(--shadow-lg)}.quiz-overview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:24px;border-bottom:2px solid var(--border-light)}.quiz-overview-header h1{font-size:32px;font-weight:700;color:var(--text-primary);margin:0}.quiz-date-badge{background:var(--primary);color:#fff;padding:10px 20px;border-radius:10px;font-size:14px;font-weight:600}.quiz-description{font-size:16px;color:var(--text-secondary);line-height:1.6;margin-bottom:32px}.quiz-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:32px}.info-item{background:var(--bg-accent);border-radius:12px;padding:24px;display:flex;align-items:center;gap:16px;border:1px solid var(--border-light)}.info-icon{font-size:32px}.info-item div{display:flex;flex-direction:column}.info-item strong{font-size:24px;font-weight:700;color:var(--primary)}.info-item span{font-size:13px;color:var(--text-secondary)}.quiz-instructions{background:#fff9e6;border-left:4px solid var(--primary);border-radius:8px;padding:24px;margin-bottom:32px}.quiz-instructions h3{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:16px}.quiz-instructions ul{list-style:none;padding:0;margin:0}.quiz-instructions li{padding:8px 0;font-size:15px;color:var(--text-secondary)}.quiz-actions{display:flex;justify-content:space-between;gap:16px;padding-top:24px;border-top:2px solid var(--border-light)}.btn-large{padding:16px 48px;font-size:18px;font-weight:700}.quiz-active-container{max-width:1000px;margin:0 auto}.quiz-active-header{background:#fff;border-radius:12px;padding:24px 32px;margin-bottom:24px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.quiz-active-header h2{font-size:24px;font-weight:700;color:var(--text-primary);margin:0 0 6px}.quiz-active-header p{color:var(--text-secondary);margin:0;font-size:14px}.quiz-progress-summary{text-align:right}.progress-text{font-size:14px;font-weight:600;color:var(--text-primary);display:block;margin-bottom:8px}.progress-bar-mini{width:200px;height:8px;background:var(--bg-accent);border-radius:10px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),#4CAF50);border-radius:10px;transition:width .3s ease}.question-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px;background:#fff;border-radius:12px;padding:20px;border:1px solid var(--border-light)}.question-tab{width:50px;height:50px;border-radius:10px;border:2px solid var(--border-light);background:#fff;font-size:16px;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .3s ease}.question-tab:hover{border-color:var(--primary);background:var(--bg-accent)}.question-tab.active{background:var(--primary);color:#fff;border-color:var(--primary);transform:scale(1.1)}.question-tab.answered{background:#e8f5e9;border-color:#4caf50;color:#4caf50}.question-tab.answered.active{background:var(--primary);color:#fff}.current-question-card{background:#fff;border-radius:16px;padding:40px;border:1px solid var(--border-light);box-shadow:var(--shadow-md);margin-bottom:24px}.question-navigation{display:flex;justify-content:space-between;gap:16px;margin-top:32px;padding-top:24px;border-top:2px solid var(--border-light)}.final-submit-section{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-radius:12px;padding:32px;text-align:center;border:2px solid #4CAF50}.submit-info{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.submit-info span:first-child{font-size:20px;font-weight:700;color:#2e7d32}.submit-info span:last-child{font-size:16px;color:var(--text-secondary)}.option{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-accent);border:2px solid var(--border-light);border-radius:10px;margin-bottom:12px;cursor:pointer;transition:all .3s ease}.option:hover{border-color:var(--primary);background:#fff}.option.selected{background:#e8f5e9;border-color:var(--primary);border-width:3px}.option input[type=radio]{display:none}.option-letter{background:var(--primary);color:#fff;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}.option.selected .option-letter{background:#2e7d32}.option-text{font-size:15px;color:var(--text-primary);line-height:1.5}.error-container{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;border:1px solid var(--border-light)}.quiz-container{max-width:900px;margin:0 auto}.quiz-header{background:var(--bg-card);border-radius:20px;padding:30px;margin-bottom:30px;border:1px solid rgba(139,92,246,.2);display:flex;justify-content:space-between;align-items:center}.quiz-header-left h1{font-size:32px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.quiz-header-left p{color:var(--text-secondary);font-size:14px}.quiz-header-actions{display:flex;gap:12px}.btn{padding:12px 24px;border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:14px}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef44444d}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 6px 16px #ef444466}.quiz-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:30px}.stat-card{background:var(--bg-card);border-radius:16px;padding:24px;border:1px solid rgba(139,92,246,.2);transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);border-color:var(--primary);box-shadow:0 8px 24px #8b5cf633}.stat-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:32px;font-weight:700;color:var(--primary)}.quiz-card{background:var(--bg-card);border-radius:20px;padding:40px;border:1px solid rgba(139,92,246,.2);margin-bottom:30px}.quiz-info{margin-bottom:30px;padding-bottom:30px;border-bottom:1px solid rgba(139,92,246,.1)}.quiz-info h2{font-size:28px;font-weight:700;margin-bottom:12px}.quiz-info p{color:var(--text-secondary);font-size:15px;line-height:1.6}.quiz-meta{display:flex;gap:24px;margin-top:16px}.quiz-meta-item{display:flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:14px}.quiz-meta-icon{width:20px;height:20px;background:var(--gradient-primary);border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#fff}.question-card{background:var(--bg-secondary);border-radius:16px;padding:32px;margin-bottom:24px;border:1px solid rgba(139,92,246,.15)}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.question-number{background:var(--gradient-primary);color:#fff;padding:8px 16px;border-radius:8px;font-weight:700;font-size:14px}.question-type{padding:6px 12px;background:#8b5cf61a;color:var(--primary-light);border-radius:6px;font-size:12px;text-transform:uppercase;letter-spacing:.5px}.question-text{font-size:18px;font-weight:600;line-height:1.6;margin-bottom:24px;color:var(--text-primary)}.options{display:flex;flex-direction:column;gap:12px}.option{background:var(--bg-card);border:2px solid rgba(139,92,246,.2);border-radius:12px;padding:16px 20px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:12px}.option:hover{border-color:var(--primary);background:var(--bg-card-hover);transform:translate(4px)}.option.selected{border-color:var(--primary);background:linear-gradient(135deg,#8b5cf61a,#ec48991a);box-shadow:0 4px 12px #8b5cf633}.option-radio{width:20px;height:20px;border:2px solid var(--text-secondary);border-radius:50%;position:relative;flex-shrink:0}.option.selected .option-radio{border-color:var(--primary)}.option.selected .option-radio:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;background:var(--gradient-primary);border-radius:50%}.option-text{color:var(--text-primary);font-size:15px;flex:1}.quiz-submit{margin-top:30px;text-align:center}.btn-submit{background:var(--gradient-primary);color:#fff;padding:16px 48px;font-size:16px;font-weight:700;border:none;border-radius:12px;cursor:pointer;transition:all .3s ease;box-shadow:0 10px 30px #8b5cf64d}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 15px 40px #8b5cf666}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.history-view{margin-top:30px}.history-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:20px;margin-bottom:30px}.history-table{background:var(--bg-card);border-radius:20px;overflow:hidden;border:1px solid rgba(139,92,246,.2)}.history-table table{width:100%;border-collapse:collapse}.history-table thead{background:var(--bg-secondary)}.history-table th{padding:20px;text-align:left;font-weight:600;color:var(--text-secondary);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:20px;border-top:1px solid rgba(139,92,246,.1);color:var(--text-primary)}.badge-pass{background:#10b9811a;color:var(--success)}.badge-fail{background:#ef44441a;color:var(--danger)}.loading{text-align:center;padding:60px;color:var(--text-secondary)}.no-quiz{text-align:center;padding:60px;background:var(--bg-card);border-radius:20px;border:1px solid rgba(139,92,246,.2)}.no-quiz h2{font-size:24px;margin-bottom:12px}.no-quiz p{color:var(--text-secondary);margin-bottom:24px}.results-page{min-height:100vh;background:var(--bg-primary);display:flex;align-items:center;justify-content:center;padding:20px}.results-container{max-width:700px;width:100%}.results-card{background:var(--bg-card);border-radius:24px;padding:50px;text-align:center;border:1px solid rgba(139,92,246,.2);box-shadow:0 20px 60px #00000080}.results-icon{width:120px;height:120px;margin:0 auto 30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:60px;position:relative}.results-icon.pass{background:linear-gradient(135deg,#10b981,#3b82f6);box-shadow:0 20px 50px #10b98166}.results-icon.fail{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 20px 50px #ef444466}.results-icon:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;background:inherit;filter:blur(20px);opacity:.5;z-index:-1}.results-title{font-size:36px;font-weight:700;margin-bottom:16px}.results-title.pass{color:#10b981}.results-title.fail{color:#ef4444}.results-message{color:var(--text-secondary);font-size:16px;margin-bottom:40px;line-height:1.6}.results-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:40px}.stat-box{background:var(--bg-secondary);border-radius:16px;padding:24px;border:1px solid rgba(139,92,246,.15)}.stat-box-label{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-box-value{font-size:28px;font-weight:700;color:var(--primary)}.results-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn{padding:14px 28px;border:none;border-radius:12px;font-weight:600;cursor:pointer;transition:all .3s ease;font-size:15px}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 8px 24px #8b5cf64d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 32px #8b5cf666}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid rgba(139,92,246,.3)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--primary)}.score-circle{width:150px;height:150px;margin:0 auto 30px;position:relative}.score-circle svg{transform:rotate(-90deg)}.score-circle-bg{fill:none;stroke:var(--bg-secondary);stroke-width:12}.score-circle-progress{fill:none;stroke:url(#gradient);stroke-width:12;stroke-linecap:round;transition:stroke-dashoffset 1s ease}.score-circle-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:32px;font-weight:700;color:var(--primary)}.projects-page{min-height:100vh;background:var(--bg-primary);display:flex}.page-header{background:#fff;border-radius:12px;padding:32px 40px;margin-bottom:32px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.page-header h1{font-size:28px;font-weight:700;margin-bottom:8px;color:var(--text-primary)}.page-header p{color:var(--text-secondary);font-size:15px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px}.project-card{background:#fff;border-radius:12px;padding:28px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;display:flex;flex-direction:column}.project-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--primary)}.project-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:12px}.project-header h3{font-size:20px;font-weight:700;color:var(--text-primary);margin:0;flex:1}.due-badge{padding:6px 12px;border-radius:6px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;flex-shrink:0}.due-badge.on-time{background:#e8f5e9;color:#2e7d32}.due-badge.due-soon{background:#fff9e6;color:#f57c00}.due-badge.overdue{background:#ffebee;color:#c62828}.project-description{color:var(--text-secondary);line-height:1.6;margin-bottom:16px;flex:1}.project-meta{display:flex;gap:20px;margin-bottom:20px;padding-top:16px;border-top:1px solid var(--border-light)}.meta-item{display:flex;align-items:center;gap:6px;font-size:14px;color:var(--text-secondary)}.meta-item span:first-child{font-size:16px}.submission-status{background:var(--bg-accent);border-radius:10px;padding:16px;margin-top:16px}.status-indicator{font-weight:600;font-size:14px;margin-bottom:12px;padding:8px 12px;border-radius:6px;display:inline-block}.status-indicator.graded{background:#e8f5e9;color:#2e7d32}.status-indicator.submitted{background:#e3f2fd;color:#1976d2}.status-indicator.pending{background:#fff9e6;color:#f57c00}.marks-display{font-size:24px;font-weight:700;color:var(--primary);margin:12px 0}.feedback-box{background:#fff;padding:16px;border-radius:8px;margin:12px 0;border:1px solid var(--border-light)}.feedback-box strong{display:block;margin-bottom:8px;color:var(--text-primary)}.feedback-box p{color:var(--text-secondary);line-height:1.6;margin:0}.no-projects{grid-column:1 / -1;text-align:center;padding:80px 20px;background:#fff;border-radius:12px;border:1px solid var(--border-light)}.no-projects-icon{font-size:80px;opacity:.3;margin-bottom:20px}.no-projects h3{font-size:22px;margin-bottom:12px;color:var(--text-primary)}.no-projects p{color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.modal-content{background:#fff;border-radius:16px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:28px 32px;border-bottom:1px solid var(--border-light)}.modal-header h2{font-size:22px;font-weight:700;color:var(--text-primary);margin:0}.modal-close{width:36px;height:36px;border-radius:50%;border:none;background:var(--bg-accent);color:var(--text-primary);font-size:24px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.modal-close:hover{background:var(--danger);color:#fff}.instructions-box{background:#e8f5e9;padding:20px;margin:24px 32px;border-radius:10px;border:1px solid #A5D6A7}.instructions-box strong{display:block;margin-bottom:8px;color:#2e7d32}.instructions-box p{color:var(--text-secondary);line-height:1.6;margin:0}.submission-form{padding:0 32px 32px}.form-group{margin-bottom:24px}.form-group label{display:block;font-size:14px;font-weight:600;margin-bottom:10px;color:var(--text-primary)}.form-group input,.form-group textarea{width:100%;padding:14px 16px;background:var(--bg-accent);border:1px solid var(--border-light);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all .3s ease;font-family:inherit}.form-group textarea{resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #7fb5391a}.form-group small{display:block;margin-top:8px;color:var(--text-muted);font-size:13px}.modal-actions{display:flex;gap:12px;margin-top:28px}.modal-actions .btn{flex:1}@media(max-width:768px){.projects-grid{grid-template-columns:1fr}.modal-content{max-height:95vh}.modal-header,.submission-form{padding-left:20px;padding-right:20px}.instructions-box{margin-left:20px;margin-right:20px}}.buzz-page{min-height:100vh;background:var(--bg-primary);display:flex}.unread-badge{background:var(--primary);color:#fff;padding:8px 16px;border-radius:20px;font-size:14px;font-weight:700;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.8}}.buzz-feed{display:flex;flex-direction:column;gap:20px}.buzz-card{background:#fff;border-radius:12px;padding:28px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .3s ease;position:relative;cursor:pointer}.buzz-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.buzz-card.unread{border-left:4px solid var(--primary);background:linear-gradient(90deg,#f0f8f0,#fff 10%)}.buzz-card.priority-urgent{border-left-color:#ef4444}.buzz-card.priority-high{border-left-color:#f59e0b}.buzz-card.priority-normal{border-left-color:var(--primary)}.buzz-card.priority-low{border-left-color:#94a3b8}.buzz-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.buzz-type{display:flex;align-items:center;gap:8px}.type-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);background:var(--bg-accent);padding:4px 10px;border-radius:6px}.buzz-time{font-size:13px;color:var(--text-muted)}.buzz-title{font-size:20px;font-weight:700;margin-bottom:12px;color:var(--text-primary)}.buzz-content{color:var(--text-secondary);line-height:1.7;margin-bottom:20px;word-wrap:break-word;white-space:pre-wrap}.buzz-link{color:var(--primary);text-decoration:none;font-weight:600;border-bottom:2px solid var(--primary);transition:all .3s ease;display:inline;margin:0 2px}.buzz-link:hover{color:#2e7d32;border-bottom-color:#2e7d32;background:#e8f5e9;padding:2px 6px;border-radius:4px}.buzz-footer{display:flex;justify-content:space-between;align-items:center;padding-top:16px;border-top:1px solid var(--border-light);font-size:13px;color:var(--text-muted)}.buzz-author{font-weight:600}.buzz-expires{color:var(--warning)}.unread-indicator{position:absolute;top:28px;right:28px;width:12px;height:12px;background:var(--primary);border-radius:50%;box-shadow:0 0 0 3px #fff,0 0 0 5px var(--primary);animation:pulse-indicator 2s infinite}@keyframes pulse-indicator{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.no-buzz{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;border:1px solid var(--border-light)}.no-buzz-icon{font-size:80px;opacity:.3;margin-bottom:20px}.no-buzz h3{font-size:22px;margin-bottom:12px;color:var(--text-primary)}.no-buzz p{color:var(--text-secondary)}@media(max-width:768px){.buzz-card{padding:20px}.buzz-title{font-size:18px}.buzz-footer{flex-direction:column;gap:8px;align-items:flex-start}}.ai-assistant-page{min-height:100vh;background:var(--bg-primary);display:flex}.chat-container{display:flex;flex-direction:column;height:calc(100vh - 48px);max-width:1200px;margin:0 auto;width:100%}.chat-header{background:#fff;border-radius:12px;padding:24px 32px;margin-bottom:20px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;justify-content:space-between;align-items:center}.chat-header h1{font-size:24px;font-weight:700;margin-bottom:4px;color:var(--text-primary)}.chat-header p{color:var(--text-secondary);font-size:14px}.chatbot-warning{background:#fff9e6;border:1px solid #FFE082;color:#f57c00;padding:14px 20px;border-radius:10px;margin-bottom:20px;font-size:14px}.messages-area{flex:1;background:#fff;border-radius:12px;padding:24px;margin-bottom:20px;overflow-y:auto;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:20px}.message{display:flex;gap:12px;align-items:flex-start}.message-user{flex-direction:row-reverse}.message-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.message-user .message-avatar{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.message-assistant .message-avatar{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.message-content{flex:1;max-width:70%}.message-user .message-content{text-align:right}.message-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:12px}.message-user .message-header{flex-direction:row-reverse}.message-sender{font-size:13px;font-weight:700;color:var(--text-primary)}.message-time{font-size:12px;color:var(--text-muted)}.message-text{background:var(--bg-accent);padding:14px 18px;border-radius:12px;font-size:15px;line-height:1.6;color:var(--text-primary)}.message-user .message-text{background:var(--primary);color:#fff;border-bottom-right-radius:4px}.message-assistant .message-text{background:var(--bg-accent);border-bottom-left-radius:4px}.message-error .message-text{background:#ffebee;color:#c62828;border:1px solid #EF9A9A}.message-text p{margin:0 0 8px}.message-text p:last-child{margin-bottom:0}.typing-indicator{display:flex;gap:6px;padding:16px}.typing-indicator span{width:8px;height:8px;background:var(--primary);border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}.chat-input-area{background:#fff;border-radius:12px;padding:20px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm)}.chat-input-form{display:flex;gap:12px;margin-bottom:12px}.chat-input{flex:1;padding:14px 18px;background:var(--bg-accent);border:1px solid var(--border-light);border-radius:10px;font-size:15px;color:var(--text-primary);transition:all .3s ease}.chat-input:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #7fb5391a}.chat-input:disabled{opacity:.6;cursor:not-allowed}.btn-send{padding:14px 28px;background:var(--primary);color:#fff;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:8px}.btn-send:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-send:disabled{opacity:.6;cursor:not-allowed}.chat-disclaimer{font-size:12px;color:var(--text-muted);text-align:center;margin:0}.messages-area::-webkit-scrollbar{width:8px}.messages-area::-webkit-scrollbar-track{background:var(--bg-accent);border-radius:4px}.messages-area::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:4px}.messages-area::-webkit-scrollbar-thumb:hover{background:var(--primary)}@media(max-width:768px){.message-content{max-width:85%}.chat-header{flex-direction:column;gap:12px;text-align:center;padding:20px}.chat-input-form{flex-direction:column}.btn-send{width:100%;justify-content:center}}.buzz-admin-page{min-height:100vh;background:var(--bg-primary);display:flex}.post-count{margin-top:12px;font-size:14px;font-weight:600;color:var(--primary);padding:8px 14px;background:#e8f5e9;border-radius:8px;display:inline-block}.admin-posts-list{display:flex;flex-direction:column;gap:20px}.admin-post-card{background:#fff;border-radius:12px;padding:24px;border:1px solid var(--border-light);box-shadow:var(--shadow-sm);transition:all .3s ease}.admin-post-card:hover{box-shadow:var(--shadow-md)}.post-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.post-info{display:flex;align-items:center;gap:12px}.post-number{background:var(--bg-accent);color:var(--text-primary);padding:4px 10px;border-radius:6px;font-size:12px;font-weight:700}.type-icon{font-size:20px}.post-type{font-size:12px;font-weight:600;text-transform:uppercase;color:var(--text-secondary);background:var(--bg-accent);padding:4px 10px;border-radius:6px}.priority-badge{padding:4px 10px;border-radius:6px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.priority-urgent{background:#ffebee;color:#c62828}.priority-high{background:#fff3e0;color:#e65100}.priority-normal{background:#e8f5e9;color:#2e7d32}.priority-low{background:#f5f5f5;color:#616161}.btn-delete-post{width:36px;height:36px;border-radius:8px;border:none;background:#ffebee;color:#c62828;font-size:18px;cursor:pointer;transition:all .3s ease}.btn-delete-post:hover{background:#c62828;color:#fff}.post-title{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.post-content{color:var(--text-secondary);line-height:1.6;margin-bottom:16px;white-space:pre-wrap;word-wrap:break-word}.post-meta{display:flex;gap:20px;flex-wrap:wrap;padding-top:16px;border-top:1px solid var(--border-light);font-size:13px;color:var(--text-muted)}.status-active{color:#2e7d32;font-weight:600}.status-inactive{color:#c62828;font-weight:600}.no-posts{text-align:center;padding:80px 20px;background:#fff;border-radius:12px;border:1px solid var(--border-light)}.no-posts-icon{font-size:80px;opacity:.3;margin-bottom:20px}.no-posts h3{font-size:22px;margin-bottom:12px;color:var(--text-primary)}.no-posts p{color:var(--text-secondary)}.modal-large{max-width:600px}.buzz-form{padding:0 32px 32px}.buzz-form .form-group{margin-bottom:24px}.buzz-form label{display:block;font-size:14px;font-weight:600;margin-bottom:10px;color:var(--text-primary)}.buzz-form input,.buzz-form textarea,.buzz-form select{width:100%;padding:14px 16px;background:var(--bg-accent);border:1px solid var(--border-light);border-radius:10px;color:var(--text-primary);font-size:15px;transition:all .3s ease;font-family:inherit}.buzz-form textarea{resize:vertical}.buzz-form input:focus,.buzz-form textarea:focus,.buzz-form select:focus{outline:none;border-color:var(--primary);background:#fff;box-shadow:0 0 0 3px #7fb5391a}.buzz-form small{display:block;margin-top:8px;color:var(--text-muted);font-size:13px}@media(max-width:768px){.post-header{flex-direction:column;align-items:flex-start;gap:12px}.post-meta{flex-direction:column;gap:8px}}:root{--bg-primary: #F8F9FA;--bg-secondary: #FFFFFF;--bg-card: #FFFFFF;--bg-card-hover: #F5F7F9;--bg-accent: #F0F4F8;--primary: #7FB539;--primary-light: #9ACC5E;--primary-dark: #6A9B2F;--primary-hover: #8BC645;--gradient-primary: linear-gradient(135deg, #7FB539 0%, #9ACC5E 100%);--gradient-hero: linear-gradient(135deg, #F8F9FA 0%, #E8F5E9 100%);--gradient-card: linear-gradient(180deg, #FFFFFF 0%, #F8F9FA 100%);--text-primary: #1A2332;--text-secondary: #5A6C7D;--text-muted: #8B95A1;--text-light: #A8B3BE;--success: #7FB539;--danger: #DC3545;--warning: #FFC107;--info: #17A2B8;--border-light: #E5E9ED;--border-medium: #D1D9E0;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .04);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .12);--shadow-xl: 0 12px 32px rgba(0, 0, 0, .15)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}.app{min-height:100vh;background:var(--bg-primary)}.container{max-width:1200px;margin:0 auto;padding:20px}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:12px;padding:32px;box-shadow:var(--shadow-md);color:var(--text-primary);margin-bottom:24px;transition:all .3s ease}.card:hover{box-shadow:var(--shadow-lg);border-color:var(--border-medium)}.card h2{font-size:20px;font-weight:700;margin-bottom:20px;color:var(--text-primary)}.btn{padding:14px 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;display:inline-flex;align-items:center;gap:8px}.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-md);font-weight:600}.btn-primary:hover{background:var(--primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-lg)}.btn-success{background:var(--gradient-success);color:#fff;box-shadow:0 8px 24px #10b9814d}.btn-success:hover{transform:translateY(-2px);box-shadow:0 12px 32px #10b98166}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 8px 24px #ef44444d}.btn-danger:hover{transform:translateY(-2px);box-shadow:0 12px 32px #ef444466}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-medium)}.btn-secondary:hover{background:var(--bg-accent);border-color:var(--primary);color:var(--primary)}.btn-small{padding:8px 16px;font-size:13px}.loading{text-align:center;padding:60px;font-size:18px;color:var(--text-secondary)}.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:14px 18px;border-radius:10px;margin-bottom:20px}.success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#6ee7b7;padding:14px 18px;border-radius:10px;margin-bottom:20px}.table-container{overflow-x:auto}.students-table{width:100%;border-collapse:collapse}.students-table thead{background:var(--bg-accent);border-bottom:2px solid var(--border-medium)}.students-table th{padding:16px 20px;text-align:left;font-weight:600;color:var(--text-primary);font-size:13px;text-transform:uppercase;letter-spacing:.5px}.students-table td{padding:16px 20px;border-bottom:1px solid var(--border-light);color:var(--text-primary)}.students-table tbody tr{transition:all .2s ease}.students-table tbody tr:hover{background:var(--bg-accent)}.badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-success,.badge-pass{background:#e8f5e9;color:#2e7d32;border:1px solid #A5D6A7}.badge-danger,.badge-fail{background:#ffebee;color:#c62828;border:1px solid #EF9A9A}.badge-warning{background:#fff9e6;color:#f57c00;border:1px solid #FFE082}.status-badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.completed{background:#10b9811a;color:var(--success)}.status-badge.not-completed{background:#f59e0b1a;color:var(--warning)}.pass-fail-badge{display:inline-block;padding:6px 12px;border-radius:6px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.pass-fail-badge.pass{background:#10b9811a;color:var(--success)}.pass-fail-badge.fail{background:#ef44441a;color:var(--danger)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-card{background:var(--bg-card);border-radius:12px;padding:24px;border:1px solid var(--border-light);transition:all .3s ease;box-shadow:var(--shadow-sm)}.stat-card:hover{transform:translateY(-2px);border-color:var(--primary);box-shadow:var(--shadow-md)}.stat-card h3{font-size:13px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;font-weight:600}.stat-card .stat-value{font-size:32px;font-weight:700;color:var(--primary);margin:0}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}#root{min-height:100vh}
