@media (width<=1023px){.navbar-container{padding:var(--spacing-md) var(--spacing-lg)}.navbar-brand-text{font-size:var(--font-size-lg)}.navbar-brand-icon{font-size:24px}}@media (width<=768px){.navbar-mobile-toggle{display:block}.navbar-links{background-color:var(--white);padding:var(--spacing-md);box-shadow:var(--shadow-md);gap:var(--spacing-xs);flex-direction:column;animation:.3s navbarSlideDown;display:none;position:absolute;top:100%;left:0;right:0}@keyframes navbarSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.navbar-links.active{display:flex}.navbar-link{text-align:center;width:100%;padding:var(--spacing-md);justify-content:center}.navbar-container{padding:var(--spacing-sm) var(--spacing-md)}.navbar-brand-text{font-size:var(--font-size-md)}.navbar-brand-icon{font-size:20px}}@media (width<=480px){.navbar-container{padding:var(--spacing-sm) var(--spacing-md)}.navbar-brand-text{font-size:var(--font-size-sm)}.navbar-brand-icon{font-size:18px}.navbar-hamburger{font-size:20px}.navbar-link{padding:var(--spacing-sm);font-size:var(--font-size-sm)}}@media (width<=768px){body.navbar-menu-open{overflow:hidden}}@media (width<=768px){.hero-title{font-size:var(--font-size-3xl)}.hero-subtitle{font-size:var(--font-size-lg)}.hero-buttons{flex-direction:column;align-items:center}.features-grid{padding:0 var(--spacing-md);grid-template-columns:1fr}.stat-number{font-size:var(--font-size-3xl)}}@keyframes loginFloat{0%,to{transform:translateY(0)rotate(0)}50%{transform:translateY(-20px)rotate(10deg)}}@keyframes loginSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes loginShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes loginSpin{to{transform:rotate(360deg)}}@media (width<=640px){.login-container{padding:var(--spacing-md)}.login-card{padding:32px 24px}.login-title{font-size:24px}.login-logo-icon{font-size:28px}.login-logo-text{font-size:22px}.login-input{padding:12px 16px 12px 44px;font-size:14px}.login-input-icon{font-size:16px;left:14px}.login-options{font-size:12px}.login-submit-btn{padding:12px;font-size:14px}}@media (width<=480px){.login-card{padding:24px 20px}.login-title{font-size:22px}.login-subtitle{font-size:12px}.login-options{flex-direction:column;align-items:flex-start;gap:12px}}@keyframes registerPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}@keyframes registerSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes registerShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes registerFadeIn{0%{opacity:0;transform:translate(10px)}to{opacity:1;transform:translate(0)}}@keyframes registerSpin{to{transform:rotate(360deg)}}@media (width<=640px){.register-card{padding:24px 20px}.register-title{font-size:24px}.register-logo-icon{font-size:28px}.register-logo-text{font-size:22px}.register-form-row{grid-template-columns:1fr;gap:0}.register-role-selector{grid-template-columns:1fr;gap:16px}.register-role-card{padding:20px}.register-step-label{font-size:10px}.register-form-actions{flex-direction:column}.register-btn{width:100%}.register-phone-prefix-text{padding:10px 12px;font-size:12px}.register-phone-input{padding:10px 12px}}@media (width<=480px){.register-card{padding:20px 16px}.register-title{font-size:22px}.register-step-number{width:32px;height:32px;font-size:14px}.register-step-indicator:before{top:16px}.register-phone-prefix-text{padding:8px 10px;font-size:11px}.register-phone-input{padding:8px 10px}}@keyframes forgotPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}@keyframes forgotSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes forgotShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes forgotSpin{to{transform:rotate(360deg)}}@keyframes forgotBounce{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@keyframes forgotFadeIn{0%{opacity:0}to{opacity:1}}@keyframes forgotModalSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (width<=640px){.forgot-modal-content{padding:0 var(--spacing-md) var(--spacing-md)}.forgot-modal-title{font-size:20px}.forgot-modal-icon{padding:var(--spacing-lg) var(--spacing-lg) 0;font-size:40px}.forgot-contact-option{padding:var(--spacing-sm)}.forgot-contact-icon{min-width:32px;font-size:24px}.forgot-contact-option strong{font-size:var(--font-size-sm)}.forgot-container{padding:var(--spacing-md)}.forgot-card{padding:var(--spacing-lg)}.forgot-title{font-size:24px}.forgot-subtitle{font-size:var(--font-size-sm)}.forgot-header-icon{font-size:40px}.forgot-success-title{font-size:24px}.forgot-success-icon{font-size:56px}.forgot-success-icon-bg{font-size:70px}}@media (width<=480px){.forgot-card{padding:var(--spacing-md)}.forgot-title{font-size:22px}.forgot-input{font-size:var(--font-size-sm)}.forgot-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}.forgot-success-title{font-size:22px}.forgot-success-icon{font-size:48px}}@media (prefers-color-scheme:dark){.forgot-card{background:#1a1a2e}.forgot-title,.forgot-success-title{color:#fff}.forgot-subtitle,.forgot-success-message{color:#a0aec0}.forgot-input{color:#fff;background:#2d2d44;border-color:#3d3d5c}.forgot-input:focus{border-color:var(--primary-color)}.forgot-back-link{border-top-color:#3d3d5c}}@keyframes resetPulse{0%,to{opacity:.5;transform:scale(1)}50%{opacity:.3;transform:scale(1.1)}}@keyframes resetSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes resetSpin{to{transform:rotate(360deg)}}@keyframes resetProgress{0%{width:0%}to{width:100%}}@keyframes resetShake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@media (width<=640px){.reset-container{padding:var(--spacing-md)}.reset-card{padding:var(--spacing-lg)}.reset-title{font-size:24px}.reset-header-icon{font-size:40px}.reset-error-title,.reset-success-title{font-size:24px}.reset-error-icon,.reset-success-icon{font-size:56px}}@media (width<=480px){.reset-card{padding:var(--spacing-md)}.reset-title{font-size:22px}.reset-subtitle{font-size:var(--font-size-sm)}.reset-input{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 40px}.reset-input-icon{left:var(--spacing-sm);font-size:16px}.reset-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}.reset-requirements-list li{font-size:var(--font-size-xs)}.reset-error-title,.reset-success-title{font-size:22px}.reset-error-icon,.reset-success-icon{font-size:48px}}@media (prefers-color-scheme:dark){.reset-card{background:#1a1a2e}.reset-title,.reset-error-title,.reset-success-title{color:#fff}.reset-subtitle,.reset-error-message,.reset-success-message{color:#a0aec0}.reset-input{color:#fff;background:#2d2d44;border-color:#3d3d5c}.reset-input:focus{border-color:var(--primary-color)}.reset-requirements{background:#2d2d44;border-color:#3d3d5c}.reset-requirements-title{color:#e2e8f0}.reset-back-link{border-top-color:#3d3d5c}}.timetable-container{background:#f5f7fa;min-height:100vh;padding:20px}.timetable-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:0 20px;display:flex}.timetable-header h2{color:#2c3e50;margin:0;font-size:28px}.timetable-subtitle{color:#7f8c8d;margin-top:5px;font-size:14px}.timetable-header-buttons{align-items:center;gap:12px;display:flex}.timetable-add-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:8px;padding:10px 20px;font-size:14px;font-weight:600;transition:transform .2s,box-shadow .2s}.timetable-add-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.timetable-download-buttons{gap:8px;display:flex}.timetable-download-btn{cursor:pointer;border:none;border-radius:8px;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;transition:all .2s;display:flex}.timetable-print-btn{color:#fff;background:linear-gradient(135deg,#9c27b0 0%,#7b1fa2 100%)}.timetable-print-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #9c27b066}.timetable-message-banner{border-radius:8px;margin-bottom:20px;padding:12px 20px;animation:.3s timetableSlideDown}.timetable-message-success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.timetable-message-error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.timetable-message-info{color:#0c5460;background:#d1ecf1;border:1px solid #bee5eb}@keyframes timetableSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.timetable-form-overlay{z-index:1000;background:#00000080;justify-content:center;align-items:center;animation:.3s timetableFadeIn;display:flex;position:fixed;inset:0}@keyframes timetableFadeIn{0%{opacity:0}to{opacity:1}}.timetable-form{background:#fff;border-radius:16px;width:90%;max-width:500px;max-height:90vh;padding:30px;animation:.3s timetableSlideUp;overflow-y:auto;box-shadow:0 20px 60px #0000004d}@keyframes timetableSlideUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}.timetable-form h3{color:#2c3e50;margin:0 0 20px;font-size:24px}.timetable-form-group{margin-bottom:20px}.timetable-form-group label{color:#555;margin-bottom:8px;font-size:14px;font-weight:500;display:block}.timetable-form-group input,.timetable-form-group select{border:1px solid #ddd;border-radius:8px;width:100%;padding:10px 12px;font-size:14px;transition:border-color .2s}.timetable-form-group input:focus,.timetable-form-group select:focus{border-color:#667eea;outline:none}.timetable-form-row{grid-template-columns:1fr 1fr;gap:15px;display:grid}.timetable-form-actions{gap:12px;margin-top:24px;display:flex}.timetable-save-btn,.timetable-cancel-btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:12px;font-size:14px;font-weight:600;transition:all .2s}.timetable-save-btn{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.timetable-save-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.timetable-cancel-btn{color:#666;background:#e0e0e0}.timetable-cancel-btn:hover:not(:disabled){background:#d0d0d0}.timetable-save-btn:disabled,.timetable-cancel-btn:disabled{opacity:.6;cursor:not-allowed}.timetable-grid{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a}.timetable-row{border-bottom:1px solid #e0e0e0;grid-template-columns:180px repeat(5,1fr);display:grid}.timetable-row:last-child{border-bottom:none}.timetable-header-row{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-weight:600}.timetable-time-col,.timetable-day-col{text-align:center;border-right:1px solid #e0e0e0;padding:15px;font-size:14px}.timetable-header-row .timetable-time-col,.timetable-header-row .timetable-day-col{border-right:1px solid #fff3}.timetable-time-col{background:#f8f9fa;font-weight:600}.timetable-cell{border-right:1px solid #e0e0e0;min-height:120px;padding:10px;transition:background .2s}.timetable-cell:hover{background:#f8f9fa}.timetable-cell-content{flex-direction:column;gap:6px;height:100%;display:flex}.timetable-topic{color:#2c3e50;font-size:14px;font-weight:600}.timetable-venue{color:#7f8c8d;font-size:12px}.timetable-teacher{color:#3498db;font-size:12px}.timetable-cell-actions{justify-content:flex-end;gap:8px;margin-top:8px;display:flex}.timetable-edit-cell-btn,.timetable-delete-cell-btn,.timetable-add-cell-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:14px;transition:all .2s}.timetable-edit-cell-btn{color:#3498db}.timetable-edit-cell-btn:hover{background:#e3f2fd}.timetable-delete-cell-btn{color:#e74c3c}.timetable-delete-cell-btn:hover{background:#fdeaea}.timetable-add-cell-btn{color:#bdc3c7;justify-content:center;align-items:center;width:100%;height:100%;font-size:24px;display:flex}.timetable-add-cell-btn:hover{color:#667eea;background:#ecf0f1}.timetable-empty-cell{color:#bdc3c7;justify-content:center;align-items:center;height:100%;font-size:12px;display:flex}.timetable-loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.timetable-spinner{border:4px solid #e0e0e0;border-top-color:#667eea;border-radius:50%;width:50px;height:50px;animation:1s linear infinite timetableSpin}@keyframes timetableSpin{to{transform:rotate(360deg)}}.timetable-loading-container p{color:#7f8c8d;margin-top:16px}.timetable-footer{text-align:center;background:#f8f9fa;border-radius:8px;margin-top:20px;padding:16px}.timetable-footer-note{color:#7f8c8d;margin:0;font-size:12px}@media (width<=768px){.timetable-container{padding:10px;overflow-x:auto}.timetable-header{flex-direction:column;align-items:flex-start;padding:0 10px}.timetable-header-buttons{flex-direction:column;width:100%}.timetable-add-btn,.timetable-download-btn{justify-content:center;width:100%}.timetable-download-buttons{flex-direction:column;width:100%}.timetable-grid{min-width:800px}.timetable-row{grid-template-columns:150px repeat(5,1fr)}.timetable-time-col,.timetable-day-col{padding:10px;font-size:12px}.timetable-topic{font-size:12px}.timetable-form-row{grid-template-columns:1fr}.timetable-form{width:95%;padding:20px}}@media (width<=480px){.timetable-time-col,.timetable-day-col{padding:6px;font-size:10px}.timetable-cell{padding:6px}.timetable-topic{font-size:10px}.timetable-venue,.timetable-teacher{font-size:9px}.timetable-edit-cell-btn,.timetable-delete-cell-btn{padding:2px 4px;font-size:10px}}.assignment-container{padding:var(--spacing-xl)}.assignment-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.assignment-title{color:var(--gray-900);margin:0;font-size:28px}.assignment-subtitle{color:var(--gray-600);margin-top:var(--spacing-xs);font-size:14px}.assignment-create-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:var(--white);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600}.assignment-create-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.assignment-message-banner{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);animation:.3s assignmentSlideDown}.assignment-message-success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.assignment-message-error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}@keyframes assignmentSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.assignment-form{background:var(--gray-100);padding:var(--spacing-lg);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);animation:.3s assignmentFadeIn}@keyframes assignmentFadeIn{0%{opacity:0}to{opacity:1}}.assignment-form-title{margin-bottom:var(--spacing-lg);color:var(--gray-900)}.assignment-form-group{margin-bottom:var(--spacing-md)}.assignment-form-label{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-weight:500;display:block}.assignment-form-input,.assignment-form-textarea,.assignment-form-select{width:100%;padding:var(--spacing-sm);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:border-color var(--transition-fast)}.assignment-form-input:focus,.assignment-form-textarea:focus,.assignment-form-select:focus{border-color:var(--primary-color);outline:none}.assignment-form-textarea{resize:vertical;min-height:100px}.assignment-form-file{width:100%;padding:var(--spacing-sm);border:1px solid var(--gray-300);border-radius:var(--radius-md)}.assignment-form-row{gap:var(--spacing-md);grid-template-columns:1fr 1fr;display:grid}.assignment-form-actions{gap:var(--spacing-md);margin-top:var(--spacing-lg);display:flex}.assignment-save-btn,.assignment-cancel-btn{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;flex:1;font-weight:600}.assignment-save-btn{background:var(--primary-color);color:var(--white)}.assignment-save-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.assignment-cancel-btn{background:var(--gray-300);color:var(--gray-700)}.assignment-cancel-btn:hover{background:var(--gray-400);transform:translateY(-2px)}.assignment-grid{gap:var(--spacing-lg);grid-template-columns:repeat(auto-fill,minmax(400px,1fr));display:grid}.assignment-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base);overflow:hidden}.assignment-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.assignment-card-header{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));padding:var(--spacing-lg);color:var(--white);justify-content:space-between;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.assignment-card-title{margin:0;font-size:18px}.assignment-status-controls{align-items:center;gap:var(--spacing-sm);display:flex}.assignment-status-badge{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-sm);background:#fff3}.assignment-status-select{border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#fff3;border:none;padding:4px 8px;font-size:12px;font-weight:500}.assignment-actions{gap:5px;display:flex}.assignment-edit-btn,.assignment-delete-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:all .2s}.assignment-edit-btn{color:#fff}.assignment-edit-btn:hover{background:#fff3;transform:scale(1.05)}.assignment-delete-btn{color:#ffebee}.assignment-delete-btn:hover{background:#f4433680;transform:scale(1.05)}.assignment-card-body{padding:var(--spacing-lg)}.assignment-description{color:var(--gray-700);margin-bottom:var(--spacing-md);line-height:1.5}.assignment-meta{background:var(--gray-100);padding:var(--spacing-md);border-radius:var(--radius-md);margin:var(--spacing-md) 0}.assignment-meta-item{margin-bottom:var(--spacing-xs);font-size:var(--font-size-sm)}.assignment-overdue{color:var(--error-color);margin-top:var(--spacing-sm);font-weight:700}.assignment-file-attachment{background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;align-items:center;gap:12px;margin:12px 0;padding:12px;display:flex}.assignment-file-badge{color:#fff;text-align:center;border-radius:20px;min-width:80px;padding:6px 12px;font-size:12px;font-weight:600}.assignment-file-info{flex-wrap:wrap;flex:1;justify-content:space-between;align-items:center;gap:8px;display:flex}.assignment-file-name{color:#333;word-break:break-all;font-size:13px}.assignment-file-actions{gap:12px;display:flex}.assignment-download-link,.assignment-preview-link{color:#2196f3;cursor:pointer;background:0 0;border:none;font-size:12px;text-decoration:none}.assignment-download-link:hover,.assignment-preview-link:hover{text-decoration:underline}.assignment-submission-area{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--gray-200)}.assignment-submitted-info{text-align:center;padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-md)}.assignment-success-icon{margin-bottom:var(--spacing-sm);font-size:32px}.assignment-late-badge{background:var(--error-color);color:#fff;margin-top:var(--spacing-xs);border-radius:12px;padding:2px 8px;font-size:11px;display:inline-block}.assignment-grade-result{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--gray-300)}.assignment-letter-grade{font-size:var(--font-size-xl);color:var(--primary-color);margin:var(--spacing-sm) 0;font-weight:700}.assignment-feedback{color:var(--gray-600);font-style:italic}.assignment-submit-form{text-align:center}.assignment-file-input{width:100%;padding:var(--spacing-md);border:2px dashed var(--gray-300);border-radius:var(--radius-md);cursor:pointer;display:none}.assignment-file-label{width:100%;padding:var(--spacing-md);border:2px dashed var(--gray-300);border-radius:var(--radius-md);cursor:pointer;text-align:center;transition:all var(--transition-fast);display:block}.assignment-file-label:hover{border-color:var(--primary-color);background:var(--gray-100)}.assignment-teacher-actions{margin-top:var(--spacing-lg)}.assignment-view-submissions-btn{width:100%;padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none}.assignment-view-submissions-btn:hover{background:var(--gray-200);transform:translateY(-2px)}.assignment-loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.assignment-spinner{border:4px solid var(--gray-300);border-top-color:var(--primary-color);border-radius:50%;width:50px;height:50px;animation:1s linear infinite assignmentSpin}@keyframes assignmentSpin{to{transform:rotate(360deg)}}.assignment-no-data{text-align:center;padding:var(--spacing-3xl);background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-600)}.assignment-preview-modal-overlay{z-index:2000;background:#000c;justify-content:center;align-items:center;animation:.3s assignmentFadeIn;display:flex;position:fixed;inset:0}.assignment-preview-modal-content{background:#fff;border-radius:12px;flex-direction:column;width:90%;max-width:900px;max-height:90vh;animation:.3s assignmentSlideUp;display:flex}@keyframes assignmentSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.assignment-preview-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.assignment-close-preview{cursor:pointer;color:#666;background:0 0;border:none;font-size:24px}.assignment-close-preview:hover{color:#f44336}.assignment-preview-body{flex:1;justify-content:center;align-items:center;min-height:400px;padding:20px;display:flex;overflow:auto}.assignment-preview-image{object-fit:contain;max-width:100%;max-height:70vh}.assignment-preview-pdf{border:none;width:100%;height:70vh}.assignment-preview-placeholder{text-align:center;padding:40px}.assignment-preview-icon{margin-bottom:16px;font-size:64px}.assignment-download-file-btn{color:#fff;background:#2196f3;border-radius:6px;margin-top:16px;padding:10px 20px;text-decoration:none;display:inline-block}@media (width<=768px){.assignment-container{padding:var(--spacing-md)}.assignment-header{flex-direction:column;align-items:flex-start}.assignment-create-btn{width:100%}.assignment-grid{gap:var(--spacing-md);grid-template-columns:1fr}.assignment-form-row{grid-template-columns:1fr}.assignment-card-header{flex-direction:column;align-items:flex-start}.assignment-status-controls{justify-content:space-between;width:100%}}@media (width<=480px){.assignment-title{font-size:24px}.assignment-card-body{padding:var(--spacing-md)}.assignment-file-info{flex-direction:column;align-items:flex-start}}.attendance-container{max-width:1400px;margin:0 auto;padding:20px}.attendance-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.attendance-title{color:#2c3e50;margin:0;font-size:28px}.attendance-header-actions{gap:12px;display:flex}.attendance-download-btn,.attendance-toggle-btn{cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.attendance-download-btn{color:#fff;background:#4caf50}.attendance-download-btn:hover{background:#45a049;transform:translateY(-1px)}.attendance-toggle-btn{color:#fff;background:#2196f3}.attendance-toggle-btn:hover{background:#1976d2;transform:translateY(-1px)}.attendance-course-filter{margin-bottom:24px}.attendance-course-select{cursor:pointer;background:#fff;border:1px solid #ddd;border-radius:6px;min-width:250px;padding:10px 16px;font-size:14px}.attendance-teacher-view{flex-direction:column;gap:32px;display:flex}.attendance-course-section{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.attendance-course-title{color:#333;border-bottom:2px solid #667eea;margin:0 0 16px;padding-bottom:8px;font-size:20px}.attendance-course-stats{gap:20px;margin-bottom:24px;display:flex}.attendance-stat-card{text-align:center;background:#f8f9fa;border-radius:8px;padding:12px 20px}.attendance-stat-value{color:#667eea;font-size:24px;font-weight:700}.attendance-stat-label{color:#666;margin-top:4px;font-size:12px}.attendance-table-wrapper,.attendance-detailed-table-wrapper{overflow-x:auto}.attendance-table,.attendance-detailed-table{border-collapse:collapse;width:100%;font-size:14px}.attendance-table th,.attendance-detailed-table th{text-align:left;color:#333;background:#f8f9fa;border-bottom:2px solid #e0e0e0;padding:12px;font-weight:600}.attendance-table td,.attendance-detailed-table td{border-bottom:1px solid #e0e0e0;padding:10px 12px}.attendance-table tr:hover,.attendance-detailed-table tr:hover{background:#f5f5f5}.attendance-percentage-cell{align-items:center;min-width:80px;height:30px;display:flex;position:relative}.attendance-percentage-bar{opacity:.3;border-radius:4px;height:100%;transition:width .3s;position:absolute;top:0;left:0}.attendance-percentage-text{z-index:1;padding-left:8px;font-weight:500;position:relative}.attendance-status-badge{border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.attendance-status-present{color:#155724;background:#d4edda}.attendance-status-absent{color:#721c24;background:#f8d7da}.attendance-status-late{color:#856404;background:#fff3cd}.attendance-status-excused{color:#0c5460;background:#d1ecf1}.attendance-student-view{flex-direction:column;gap:32px;display:flex}.attendance-student-course{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.attendance-student-stats{flex-wrap:wrap;align-items:center;gap:32px;margin-bottom:24px;display:flex}.attendance-stat-circle{width:120px;height:120px;position:relative}.attendance-stat-circle svg{width:100%;height:100%}.attendance-stat-circle-percentage{color:#333;font-size:20px;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.attendance-student-stats-details{flex:1;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px;display:grid}.attendance-stats-item{background:#f8f9fa;border-radius:6px;justify-content:space-between;padding:8px 12px;display:flex}.attendance-stats-label{color:#666;font-size:13px}.attendance-stats-value{font-size:16px;font-weight:700}.attendance-stats-present{color:#4caf50}.attendance-stats-late{color:#ff9800}.attendance-stats-absent{color:#f44336}.attendance-detailed-section{border-top:1px solid #e0e0e0;margin-top:24px;padding-top:24px}.attendance-detailed-title{color:#555;margin:0 0 16px;font-size:18px}.attendance-empty{text-align:center;color:#999;background:#fff;border-radius:12px;padding:60px 20px}.attendance-loading{text-align:center;color:#666;padding:50px;font-size:18px}@media (width<=768px){.attendance-container{padding:12px}.attendance-header{flex-direction:column;align-items:flex-start}.attendance-header-actions{flex-direction:column;width:100%}.attendance-download-btn,.attendance-toggle-btn,.attendance-course-select{width:100%}.attendance-course-stats{flex-direction:column}.attendance-student-stats{flex-direction:column;align-items:center}.attendance-student-stats-details{width:100%}.attendance-table th,.attendance-table td{padding:8px;font-size:12px}}@media (width<=480px){.attendance-title{font-size:22px}.attendance-stat-card{padding:8px 16px}.attendance-stat-value{font-size:20px}}.announcement-container{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.announcement-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.announcement-title{color:var(--gray-900);margin:0;font-size:28px}.announcement-subtitle{color:var(--gray-600);margin-top:var(--spacing-xs);font-size:14px}.announcement-post-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:var(--white);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;font-weight:600}.announcement-post-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.announcement-form{background:var(--gray-100);padding:var(--spacing-xl);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);animation:.3s announcementSlideDown}@keyframes announcementSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.announcement-form-title{margin-bottom:var(--spacing-lg);color:var(--gray-900)}.announcement-form-group{margin-bottom:var(--spacing-md)}.announcement-form-label{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-weight:500;display:block}.announcement-form-input,.announcement-form-textarea,.announcement-form-select{width:100%;padding:var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all var(--transition-fast)}.announcement-form-input:focus,.announcement-form-textarea:focus,.announcement-form-select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.announcement-form-textarea{resize:vertical;min-height:120px}.announcement-form-file{width:100%;padding:var(--spacing-sm);border:1px solid var(--gray-300);border-radius:var(--radius-md)}.announcement-form-hint{margin-top:var(--spacing-xs);color:var(--gray-500);font-size:12px;display:block}.announcement-checkbox-label{align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);cursor:pointer;display:flex}.announcement-form-actions{gap:var(--spacing-md);margin-top:var(--spacing-lg);display:flex}.announcement-save-btn,.announcement-cancel-btn{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;flex:1;font-weight:600}.announcement-save-btn{background:var(--primary-color);color:var(--white)}.announcement-save-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.announcement-cancel-btn{background:var(--gray-300);color:var(--gray-700)}.announcement-cancel-btn:hover{background:var(--gray-400);transform:translateY(-2px)}.announcement-carousel{border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);animation:.5s announcementFadeIn;overflow:hidden}@keyframes announcementFadeIn{0%{opacity:0}to{opacity:1}}.announcement-carousel-container{align-items:center;min-height:400px;display:flex;position:relative}.announcement-carousel-btn{color:#fff;cursor:pointer;z-index:10;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);background:#ffffff4d;border:none;border-radius:50%;width:50px;height:50px;font-size:24px;transition:all .3s;position:absolute;top:50%;transform:translateY(-50%)}.announcement-carousel-btn:hover{background:#ffffff80;transform:translateY(-50%)scale(1.1)}.announcement-carousel-prev{left:20px}.announcement-carousel-next{right:20px}.announcement-carousel-slide{flex:1;justify-content:center;align-items:center;min-height:400px;padding:40px 60px;display:flex}.announcement-carousel-card{text-align:center;color:#fff;max-width:800px;margin:0 auto}.announcement-carousel-badge{letter-spacing:1px;background:#fff3;border-radius:30px;margin-bottom:20px;padding:8px 20px;font-size:12px;font-weight:600;display:inline-block}.announcement-carousel-title{margin-bottom:20px;font-size:32px;line-height:1.3}.announcement-carousel-content{opacity:.95;margin-bottom:20px;font-size:16px;line-height:1.6}.announcement-carousel-meta{opacity:.9;justify-content:center;gap:20px;margin-bottom:20px;font-size:14px;display:flex}.announcement-carousel-course{background:#fff3;border-radius:20px;padding:4px 12px}.announcement-carousel-attachment{color:#fff;background:#fff3;border-radius:8px;margin-bottom:20px;padding:8px 16px;text-decoration:none;transition:all .3s;display:inline-block}.announcement-carousel-attachment:hover{background:#ffffff4d;transform:translateY(-2px)}.announcement-carousel-footer{opacity:.8;font-size:12px}.announcement-carousel-actions{justify-content:center;gap:12px;margin-top:20px;display:flex}.announcement-carousel-dots{background:#0000001a;justify-content:center;gap:12px;padding:20px;display:flex}.announcement-carousel-dot{cursor:pointer;background:#ffffff80;border:none;border-radius:50%;width:10px;height:10px;transition:all .3s}.announcement-carousel-dot.active{background:#fff;border-radius:10px;width:30px}.announcement-list{margin-top:var(--spacing-xl)}.announcement-list-title{margin-bottom:var(--spacing-lg);color:var(--gray-800);border-left:4px solid var(--primary-color);padding-left:var(--spacing-md);font-size:20px}.announcement-grid{gap:var(--spacing-lg);flex-direction:column;display:flex}.announcement-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-base);border:1px solid var(--gray-200)}.announcement-card:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.announcement-card-header{margin-bottom:var(--spacing-lg);justify-content:space-between;align-items:flex-start;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.announcement-card-title{color:var(--gray-900);flex:1;margin:0;font-size:18px}.announcement-card-meta{gap:var(--spacing-md);align-items:center;font-size:12px;display:flex}.announcement-card-course{background:var(--primary-light);color:#fff;border-radius:20px;padding:4px 12px}.announcement-card-date{color:var(--gray-600)}.announcement-card-actions{gap:8px;display:flex}.announcement-edit-btn,.announcement-delete-btn{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:16px;transition:all .2s}.announcement-edit-btn{color:#3498db}.announcement-edit-btn:hover{background:#e3f2fd;transform:scale(1.05)}.announcement-delete-btn{color:#e74c3c}.announcement-delete-btn:hover{background:#fdeaea;transform:scale(1.05)}.announcement-card-content{margin-bottom:var(--spacing-lg)}.announcement-card-content p{color:var(--gray-700);margin-bottom:var(--spacing-md);line-height:1.6}.announcement-card-attachment{align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-100);color:var(--primary-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);transition:all var(--transition-fast);text-decoration:none;display:inline-flex}.announcement-card-attachment:hover{background:var(--primary-color);color:var(--white)}.announcement-card-footer{padding-top:var(--spacing-md);border-top:1px solid var(--gray-200);color:var(--gray-600);font-size:12px}.announcement-card-author{font-style:italic}.announcement-empty{text-align:center;padding:var(--spacing-3xl);background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-600)}.announcement-loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.announcement-spinner{border:4px solid var(--gray-300);border-top-color:var(--primary-color);border-radius:50%;width:50px;height:50px;animation:1s linear infinite announcementSpin}@keyframes announcementSpin{to{transform:rotate(360deg)}}.announcement-carousel-attachment,.announcement-card-attachment{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:8px;align-items:center;gap:8px;margin-bottom:20px;padding:8px 16px;font-size:14px;font-weight:500;text-decoration:none;transition:all .3s;display:inline-flex}.announcement-card-attachment{background:var(--gray-100);color:var(--primary-color);margin-bottom:0}.announcement-carousel-attachment:hover:not(:disabled),.announcement-card-attachment:hover:not(:disabled){transform:translateY(-2px)}.announcement-carousel-attachment:hover:not(:disabled){background:#ffffff4d}.announcement-card-attachment:hover:not(:disabled){background:var(--primary-color);color:var(--white)}.announcement-carousel-attachment:disabled,.announcement-card-attachment:disabled{opacity:.6;cursor:not-allowed}@media (width<=768px){.announcement-container{padding:var(--spacing-md)}.announcement-header{flex-direction:column;align-items:flex-start}.announcement-post-btn{width:100%}.announcement-carousel-container{min-height:500px}.announcement-carousel-slide{padding:20px}.announcement-carousel-title{font-size:22px}.announcement-carousel-content{font-size:14px}.announcement-carousel-meta{flex-direction:column;align-items:center;gap:8px}.announcement-carousel-btn{width:35px;height:35px;font-size:18px}.announcement-card-header{flex-direction:column}.announcement-card-meta{order:2}.announcement-card-actions{order:1;align-self:flex-end}.announcement-form-actions{flex-direction:column}}@media (width<=480px){.announcement-title{font-size:24px}.announcement-carousel-title{font-size:18px}.announcement-carousel-card{padding:20px}}.qna-container{padding:var(--spacing-xl);max-width:1200px;margin:0 auto}.qna-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.qna-header h2{color:var(--gray-900);margin:0;font-size:28px}.qna-subtitle{color:var(--gray-600);margin-top:var(--spacing-xs);font-size:14px}.qna-ask-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--primary-color);color:var(--white);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;font-weight:600}.qna-ask-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.qna-course-filter{margin-bottom:var(--spacing-xl)}.qna-course-select{padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);cursor:pointer;min-width:250px;transition:all var(--transition-fast);background:#fff}.qna-course-select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.qna-question-form{background:var(--gray-100);padding:var(--spacing-xl);border-radius:var(--radius-lg);margin-bottom:var(--spacing-xl);animation:.3s qnaSlideDown}.qna-form-title{margin-bottom:var(--spacing-lg);color:var(--gray-900);font-size:24px}.qna-form-group{margin-bottom:var(--spacing-md)}.qna-form-label{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-size:14px;font-weight:500;display:block}.qna-form-input,.qna-form-textarea,.qna-form-select{width:100%;padding:var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all var(--transition-fast);font-family:inherit}.qna-form-input:focus,.qna-form-textarea:focus,.qna-form-select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.qna-form-textarea{resize:vertical;min-height:120px}.qna-form-hint{margin-top:var(--spacing-xs);color:var(--gray-500);font-size:12px;display:block}.qna-form-actions{gap:var(--spacing-md);margin-top:var(--spacing-lg);display:flex}.qna-save-btn,.qna-cancel-btn{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;flex:1;font-weight:600}.qna-save-btn{background:var(--primary-color);color:var(--white)}.qna-save-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.qna-cancel-btn{background:var(--gray-200);color:var(--gray-700)}.qna-cancel-btn:hover{background:var(--gray-300);transform:translateY(-2px)}.qna-questions-list{gap:var(--spacing-xl);flex-direction:column;display:flex}.qna-question-card{background:var(--white);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.qna-question-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.qna-question-header{margin-bottom:var(--spacing-lg)}.qna-question-title{align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-sm);flex-wrap:wrap;display:flex}.qna-question-title h3{color:var(--gray-900);font-size:var(--font-size-xl);margin:0}.qna-pinned-badge{background:var(--warning-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.qna-answered-badge{background:var(--success-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.qna-question-meta{gap:var(--spacing-md);flex-wrap:wrap;align-items:center;display:flex}.qna-course-tag{background:var(--primary-light);color:var(--white);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:500}.qna-tags{gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.qna-tag{background:var(--gray-200);color:var(--gray-700);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs)}.qna-question-content{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background:var(--gray-50);border-radius:var(--radius-md)}.qna-question-content p{color:var(--gray-700);margin:0;line-height:1.6}.qna-question-footer{gap:var(--spacing-lg);padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--gray-200);color:var(--gray-600);font-size:var(--font-size-sm);flex-wrap:wrap;display:flex}.qna-asked-by,.qna-date,.qna-answer-count{align-items:center;gap:var(--spacing-xs);display:inline-flex}.qna-teacher-badge{background:var(--primary-color);color:#fff;border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600}.qna-answers-section{margin-top:var(--spacing-lg)}.qna-answers-title{margin-bottom:var(--spacing-md);color:var(--gray-700);font-size:18px}.qna-answer-card{background:var(--gray-50);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);border-left:3px solid var(--gray-400);transition:all var(--transition-fast)}.qna-answer-card:hover{transform:translate(5px)}.qna-answer-accepted{border-left-color:var(--success-color);background:#4caf501a}.qna-answer-header{margin-bottom:var(--spacing-sm);justify-content:space-between;align-items:center;gap:var(--spacing-sm);flex-wrap:wrap;display:flex}.qna-answerer{color:var(--primary-color);font-weight:700}.qna-answer-date{font-size:var(--font-size-xs);color:var(--gray-600)}.qna-accepted-badge{background:var(--success-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:600}.qna-answer-content{margin-bottom:var(--spacing-md)}.qna-answer-content p{color:var(--gray-700);margin:0;line-height:1.5}.qna-answer-actions{gap:var(--spacing-sm);flex-wrap:wrap;align-items:center;display:flex}.qna-vote-btn{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast);border:none;align-items:center;gap:4px;display:inline-flex}.qna-upvote-btn{background:var(--gray-200);color:var(--gray-700)}.qna-upvote-btn:hover{color:#4caf50;background:#e8f5e9}.qna-upvote-btn.qna-active{color:#fff;background:#4caf50}.qna-downvote-btn{background:var(--gray-200);color:var(--gray-700)}.qna-downvote-btn:hover{color:#f44336;background:#ffebee}.qna-downvote-btn.qna-active{color:#fff;background:#f44336}.qna-net-votes{padding:var(--spacing-xs) var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--gray-700);font-weight:700}.qna-accept-btn{background:var(--success-color);color:var(--white);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast);border:none}.qna-accept-btn:hover{transform:translateY(-1px);box-shadow:0 2px 8px #4caf504d}.qna-accepted-label{color:var(--success-color);font-weight:600;font-size:var(--font-size-sm)}.qna-answer-btn{background:var(--primary-color);color:var(--white);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);margin-top:var(--spacing-md);transition:all var(--transition-fast);border:none}.qna-answer-btn:hover{background:var(--primary-dark);transform:translateY(-2px)}.qna-answer-form{margin-top:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-md);animation:.3s qnaSlideDown}.qna-answer-textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);resize:vertical;font-family:inherit}.qna-answer-textarea:focus{border-color:var(--primary-color);outline:none}.qna-no-questions,.qna-no-answers{text-align:center;padding:var(--spacing-3xl);background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-600)}.qna-loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.qna-spinner{border:4px solid var(--gray-300);border-top-color:var(--primary-color);border-radius:50%;width:50px;height:50px;animation:1s linear infinite qnaSpin}@keyframes qnaSpin{to{transform:rotate(360deg)}}@keyframes qnaSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (width<=1023px){.qna-container{padding:var(--spacing-lg)}.qna-header h2{font-size:24px}}@media (width<=768px){.qna-container{padding:var(--spacing-md)}.qna-header{flex-direction:column;align-items:flex-start}.qna-ask-btn{width:100%}.qna-question-card{padding:var(--spacing-lg)}.qna-question-title{flex-direction:column;align-items:flex-start}.qna-question-title h3{font-size:18px}.qna-question-footer{gap:var(--spacing-sm);flex-direction:column}.qna-answer-header{flex-direction:column;align-items:flex-start}.qna-answer-actions{flex-wrap:wrap}.qna-form-actions{flex-direction:column}.qna-save-btn,.qna-cancel-btn{width:100%}}@media (width<=480px){.qna-container{padding:var(--spacing-sm)}.qna-question-card{padding:var(--spacing-md)}.qna-question-title h3{font-size:16px}.qna-question-content p{font-size:14px}.qna-answer-card{padding:var(--spacing-sm)}.qna-vote-btn{padding:var(--spacing-xs) var(--spacing-sm);font-size:11px}}@media print{.qna-ask-btn,.qna-answer-btn,.qna-accept-btn,.qna-vote-btn,.qna-form-actions{display:none}.qna-question-card,.qna-answer-card{break-inside:avoid;page-break-inside:avoid;box-shadow:none;border:1px solid #ddd}}.analysis-container{padding:var(--spacing-xl);background:linear-gradient(135deg,#f5f7fa 0%,#f0f2f5 100%);max-width:1400px;min-height:100vh;margin:0 auto}.analysis-header{text-align:center;margin-bottom:var(--spacing-xl)}.analysis-title{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;margin-bottom:var(--spacing-sm);-webkit-background-clip:text;background-clip:text;font-size:32px}.analysis-subtitle{color:var(--gray-600);font-size:14px}.analysis-course-selector{margin-bottom:var(--spacing-xl);text-align:center}.analysis-course-select{padding:var(--spacing-md) var(--spacing-xl);border:2px solid var(--gray-300);border-radius:var(--radius-lg);font-size:var(--font-size-md);cursor:pointer;min-width:300px;transition:all var(--transition-fast);background:#fff}.analysis-course-select:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.analysis-tabs{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);justify-content:center;display:flex}.analysis-tab{padding:var(--spacing-md) var(--spacing-xl);cursor:pointer;font-size:var(--font-size-md);color:var(--gray-600);transition:all var(--transition-fast);border-radius:var(--radius-lg);background:#fff;border:none;font-weight:600}.analysis-tab:hover{background:var(--primary-color);color:#fff;transform:translateY(-2px)}.analysis-tab.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 15px #667eea4d}.analysis-section-header{margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;display:flex}.analysis-section-title{color:var(--gray-900);margin:0;font-size:24px}.analysis-section-code{color:var(--gray-600);margin-top:var(--spacing-xs);font-size:14px}.analysis-section-header-small{margin:var(--spacing-lg) 0 var(--spacing-md);justify-content:space-between;align-items:center;display:flex}.analysis-download-buttons{gap:var(--spacing-sm);display:flex}.analysis-download-csv,.analysis-print{padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast);border:none;font-weight:500}.analysis-download-csv{color:#fff;background:#4caf50}.analysis-download-csv:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.analysis-print{color:#fff;background:#2196f3}.analysis-print:hover{background:#1976d2;transform:translateY(-2px);box-shadow:0 4px 12px #2196f34d}.analysis-stats-grid{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.analysis-stat-card{padding:var(--spacing-xl);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);transition:all var(--transition-fast);background:#fff}.analysis-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-5px)}.analysis-stat-value{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:48px;font-weight:700}.analysis-stat-label{color:var(--gray-600);margin-top:var(--spacing-sm);font-size:14px}.analysis-stat-grade{margin-top:var(--spacing-sm);color:#fff;border-radius:20px;padding:4px 12px;font-size:14px;font-weight:700;display:inline-block}.analysis-assignments{gap:var(--spacing-lg);flex-direction:column;display:flex}.analysis-assignment-card{border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-fast);background:#fff}.analysis-assignment-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.analysis-assignment-header{justify-content:space-between;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-md);border-bottom:2px solid var(--gray-200);flex-wrap:wrap;display:flex}.analysis-assignment-info{flex:1}.analysis-assignment-title{margin:0 0 var(--spacing-sm) 0;color:var(--gray-900);font-size:18px}.analysis-assignment-stats{gap:var(--spacing-md);flex-wrap:wrap;display:flex}.analysis-assignment-stat{font-size:var(--font-size-sm);color:var(--gray-600)}.analysis-grade-circle{flex-shrink:0;width:100px;height:100px;position:relative}.analysis-circle-svg{width:100%;height:100%;transform:rotate(-90deg)}.analysis-circle-progress{transition:stroke-dashoffset 1s}.analysis-circle-content{text-align:center;flex-direction:column;align-items:center;gap:2px;display:flex;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.analysis-circle-percentage{color:var(--gray-900);font-size:16px;font-weight:700}.analysis-circle-grade{color:#fff;border-radius:12px;padding:2px 6px;font-size:10px;font-weight:700}.analysis-table-wrapper{margin-top:var(--spacing-md);overflow-x:auto}.analysis-table{border-collapse:collapse;border-radius:var(--radius-lg);width:100%;box-shadow:var(--shadow-sm);background:#fff;overflow:hidden}.analysis-table th,.analysis-table td{padding:var(--spacing-md);text-align:left;border-bottom:1px solid var(--gray-200)}.analysis-table th{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);font-weight:600}.analysis-table tr:hover{background:var(--gray-100)}.analysis-percentage-cell{align-items:center;min-width:100px;height:30px;display:flex;position:relative}.analysis-percentage-bar{border-radius:var(--radius-sm);opacity:.3;height:100%;transition:width .5s;position:absolute;top:0;left:0}.analysis-percentage-text{z-index:1;padding-left:var(--spacing-sm);font-weight:500;position:relative}.analysis-grade-badge{color:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-block}.analysis-toggle-detail{padding:var(--spacing-xs) var(--spacing-md);background:var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;font-size:var(--font-size-sm);transition:all var(--transition-fast);border:none}.analysis-toggle-detail:hover{background:var(--gray-300);transform:translateY(-2px)}.analysis-detailed-attendance{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background:var(--gray-100);border-radius:var(--radius-lg)}.analysis-session-grid{gap:var(--spacing-md);margin-top:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.analysis-session-card{border-radius:var(--radius-md);padding:var(--spacing-md);border-left:4px solid var(--primary-color);transition:all var(--transition-fast);background:#fff}.analysis-session-card:hover{box-shadow:var(--shadow-sm);transform:translate(5px)}.analysis-session-header{justify-content:space-between;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);flex-wrap:wrap;display:flex}.analysis-session-date{color:var(--gray-800);font-weight:600}.analysis-session-time{font-size:var(--font-size-sm);color:var(--gray-600)}.analysis-session-status{border-radius:12px;padding:2px 8px;font-size:11px;font-weight:600}.analysis-session-status.active{color:#fff;background:#4caf50}.analysis-session-status.closed{color:#fff;background:#9e9e9e}.analysis-session-stats{gap:var(--spacing-md);flex-wrap:wrap;display:flex}.analysis-session-stat{font-size:var(--font-size-sm);color:var(--gray-700)}.analysis-personal-stats{margin-top:var(--spacing-xl)}.analysis-personal-card{gap:var(--spacing-xl);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);background:#fff;flex-wrap:wrap;align-items:center;display:flex}.analysis-personal-circle{flex-shrink:0;width:150px;height:150px;position:relative}.analysis-personal-circle svg{width:100%;height:100%}.analysis-personal-circle .analysis-circle-percentage{font-size:22px}.analysis-personal-circle .analysis-circle-grade{padding:3px 10px;font-size:12px}.analysis-personal-details{gap:var(--spacing-md);flex:1;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.analysis-personal-item{padding:var(--spacing-sm);background:var(--gray-100);border-radius:var(--radius-md);justify-content:space-between;display:flex}.analysis-personal-label{color:var(--gray-600)}.analysis-personal-value{color:var(--gray-900);font-weight:700}.analysis-daily-trend{margin-top:var(--spacing-xl)}.analysis-trend-chart{gap:var(--spacing-md);padding:var(--spacing-md) 0;align-items:flex-end;display:flex;overflow-x:auto}.analysis-trend-bar{flex-direction:column;align-items:center;min-width:70px;display:flex}.analysis-trend-bar-fill{border-radius:var(--radius-md) var(--radius-md) 0 0;width:40px;margin-bottom:var(--spacing-sm);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);transition:height .5s}.analysis-trend-label{font-size:var(--font-size-xs);color:var(--gray-600);text-align:center}.analysis-trend-value{font-size:var(--font-size-xs);margin-top:var(--spacing-xs);color:var(--gray-700);font-weight:700}.analysis-loading{text-align:center;padding:var(--spacing-3xl);color:var(--gray-600);font-size:18px}@media (width<=768px){.analysis-container{padding:var(--spacing-md)}.analysis-title{font-size:24px}.analysis-tabs{flex-direction:column}.analysis-section-header{text-align:center;gap:var(--spacing-md);flex-direction:column}.analysis-download-buttons{flex-direction:column;width:100%}.analysis-download-csv,.analysis-print{width:100%}.analysis-assignment-header{flex-direction:column;align-items:flex-start}.analysis-grade-circle{margin-top:var(--spacing-md);align-self:center}.analysis-personal-card{text-align:center;flex-direction:column}.analysis-personal-circle{width:120px;height:120px}.analysis-personal-circle .analysis-circle-percentage{font-size:18px}.analysis-session-grid{grid-template-columns:1fr}}@media (width<=480px){.analysis-stats-grid{grid-template-columns:1fr}.analysis-session-header{flex-direction:column;align-items:flex-start}}.course-enrollment-container{max-width:1200px;margin:0 auto;padding:20px}.course-enrollment-title{color:#333;margin-bottom:10px;font-size:28px}.course-enrollment-info{color:#666;background-color:#f0f8ff;border-radius:5px;margin-bottom:20px;padding:10px}.course-enrollment-message{border-radius:5px;justify-content:space-between;align-items:center;margin-bottom:20px;padding:12px;animation:.3s courseEnrollmentSlideIn;display:flex}@keyframes courseEnrollmentSlideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.course-enrollment-message-success{color:#155724;background-color:#d4edda;border:1px solid #c3e6cb}.course-enrollment-message-error{color:#721c24;background-color:#f8d7da;border:1px solid #f5c6cb}.course-enrollment-message-close{cursor:pointer;color:inherit;background:0 0;border:none;padding:0 5px;font-size:20px}.course-enrollment-message-close:hover{opacity:.7}.course-enrollment-grid{grid-template-columns:1fr 1.5fr;gap:30px;display:grid}.course-enrollment-my-courses,.course-enrollment-available-courses{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 10px #0000001a}.course-enrollment-section-title{color:#333;border-bottom:2px solid #4caf50;margin-top:0;margin-bottom:20px;padding-bottom:10px;font-size:20px}.course-enrollment-courses-list{flex-direction:column;gap:15px;max-height:500px;display:flex;overflow-y:auto}.course-enrollment-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:15px;transition:all .3s}.course-enrollment-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.course-enrollment-card-enrolled{background-color:#f0fff0;border-left:4px solid #4caf50}.course-enrollment-card-disabled{opacity:.6;background-color:#f5f5f5}.course-enrollment-card-code{color:#4caf50;margin-bottom:5px;font-size:14px;font-weight:700}.course-enrollment-card-name{color:#333;margin-bottom:8px;font-size:16px;font-weight:600}.course-enrollment-card-desc{color:#666;margin-bottom:12px;font-size:14px;line-height:1.4}.course-enrollment-card-date{color:#888;margin-bottom:10px;font-size:12px}.course-enrollment-select-btn{color:#fff;cursor:pointer;background-color:#4caf50;border:none;border-radius:5px;width:100%;padding:8px 16px;font-size:14px;transition:all .3s}.course-enrollment-select-btn:hover{background-color:#45a049;transform:translateY(-1px)}.course-enrollment-select-btn-selected{background-color:#2196f3}.course-enrollment-select-btn-selected:hover{background-color:#0b7dda}.course-enrollment-select-btn:disabled{cursor:not-allowed;background-color:#ccc;transform:none}.course-enrollment-drop-btn{color:#fff;cursor:pointer;background-color:#f44336;border:none;border-radius:5px;width:100%;margin-top:10px;padding:8px 16px;font-size:14px;transition:all .3s}.course-enrollment-drop-btn:hover{background-color:#da190b;transform:translateY(-1px)}.course-enrollment-enrolled-badge{color:#fff;background-color:#4caf50;border-radius:20px;margin-top:10px;padding:4px 12px;font-size:12px;display:inline-block}.course-enrollment-enroll-btn{color:#fff;cursor:pointer;background-color:#2196f3;border:none;border-radius:5px;width:100%;margin-top:20px;padding:12px 24px;font-size:16px;font-weight:700;transition:all .3s}.course-enrollment-enroll-btn:hover{background-color:#0b7dda;transform:translateY(-2px);box-shadow:0 4px 12px #2196f34d}.course-enrollment-empty{text-align:center;color:#999;padding:40px}.course-enrollment-loading{text-align:center;color:#666;padding:50px;font-size:18px}.course-enrollment-courses-list::-webkit-scrollbar{width:8px}.course-enrollment-courses-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.course-enrollment-courses-list::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.course-enrollment-courses-list::-webkit-scrollbar-thumb:hover{background:#555}.loading-spinner{border:4px solid #f3f3f3;border-top-color:#4caf50;border-radius:50%;width:40px;height:40px;margin:0 auto 15px;animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.course-enrollment-empty-state{text-align:center;padding:40px 20px}.course-enrollment-empty-hint{color:#888;margin-top:8px;font-size:12px}.course-enrollment-info.warning{color:#e65100;background-color:#fff3e0;border-left:4px solid #ff9800}.course-enrollment-loading{text-align:center;padding:60px 20px}.course-enrollment-loading p{color:#666;margin-top:10px}.course-enrollment-back-btn-container{margin-bottom:20px}.course-enrollment-back-btn{color:#2196f3;cursor:pointer;background:#f0f7ff;border:none;border-radius:8px;align-items:center;gap:8px;padding:10px 20px;font-size:16px;font-weight:500;transition:all .3s;display:inline-flex}.course-enrollment-back-btn:hover{color:#0b7dda;background:#e3f2fd;transform:translate(-4px)}.course-enrollment-back-btn:active{transform:translate(-2px)}@media (width<=1023px){.course-enrollment-grid{gap:20px}.course-enrollment-title{font-size:24px}}@media (width<=768px){.course-enrollment-container{padding:10px}.course-enrollment-grid{grid-template-columns:1fr;gap:20px}.course-enrollment-my-courses,.course-enrollment-available-courses{padding:15px}.course-enrollment-section-title{font-size:18px}.course-enrollment-card-name{font-size:14px}.course-enrollment-card-desc{font-size:12px}.course-enrollment-select-btn,.course-enrollment-drop-btn{padding:6px 12px;font-size:12px}.course-enrollment-enroll-btn{padding:10px 20px;font-size:14px}.course-enrollment-title{font-size:22px}.course-enrollment-info{font-size:14px}}@media (width<=480px){.course-enrollment-container{padding:8px}.course-enrollment-card{padding:10px}.course-enrollment-card-code{font-size:11px}.course-enrollment-card-name{font-size:13px}.course-enrollment-card-desc{font-size:11px}.course-enrollment-section-title{font-size:16px}.course-enrollment-empty{padding:20px;font-size:14px}}@media print{.course-enrollment-select-btn,.course-enrollment-drop-btn,.course-enrollment-enroll-btn,.course-enrollment-message-close{display:none}.course-enrollment-card{break-inside:avoid;page-break-inside:avoid}.course-enrollment-container{padding:0}}.attendance-marking-container{max-width:1200px;margin:0 auto;padding:20px}.attendance-marking-title{color:#333;margin-bottom:20px;font-size:28px}.attendance-marking-message{border-radius:5px;margin-bottom:20px;padding:12px 20px;animation:.3s attendanceMarkingSlideDown}@keyframes attendanceMarkingSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.attendance-marking-message-success{color:#155724;background-color:#d4edda;border-left:4px solid #28a745}.attendance-marking-message-error{color:#721c24;background-color:#f8d7da;border-left:4px solid #dc3545}.attendance-marking-message-warning{color:#856404;background-color:#fff3cd;border-left:4px solid #ffc107}.attendance-marking-no-sessions{text-align:center;background:#fff;border-radius:10px;padding:60px 20px;box-shadow:0 2px 10px #0000001a}.attendance-marking-no-sessions-title{color:#333;margin:10px 0;font-size:18px;font-weight:500}.attendance-marking-no-sessions-subtitle{color:#666;margin:10px 0;font-size:16px}.attendance-marking-sessions-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px;display:grid}.attendance-marking-session-card{background:#fff;border-top:4px solid #4caf50;border-radius:10px;padding:20px;transition:all .3s;box-shadow:0 2px 10px #0000001a}.attendance-marking-session-card:hover{transform:translateY(-3px);box-shadow:0 4px 20px #00000026}.attendance-marking-session-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;display:flex}.attendance-marking-session-title{color:#333;margin:0;font-size:18px}.attendance-marking-active-badge{color:#fff;background-color:#4caf50;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:700;animation:2s infinite attendanceMarkingPulse}@keyframes attendanceMarkingPulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.attendance-marking-session-details{margin-bottom:20px}.attendance-marking-session-detail{color:#555;margin:8px 0;font-size:14px}.attendance-marking-session-detail:first-child{margin-top:0}.attendance-marking-mark-btn{color:#fff;cursor:pointer;background-color:#4caf50;border:none;border-radius:5px;width:100%;padding:12px 20px;font-size:16px;font-weight:700;transition:all .3s}.attendance-marking-mark-btn:hover:not(:disabled){background-color:#45a049;transform:scale(1.02)}.attendance-marking-mark-btn:disabled{cursor:not-allowed;background-color:#ccc;transform:none}.attendance-marking-marked{background-color:#2196f3}.attendance-marking-marked:hover:not(:disabled){background-color:#0b7dda}.attendance-marking-loading{text-align:center;color:#666;padding:50px;font-size:18px}.attendance-marking-not-enrolled{text-align:center;color:#f44336;background-color:#ffebee;border-radius:5px;margin-top:10px;padding:8px;font-size:14px}@media (width<=1023px){.attendance-marking-container{padding:15px}.attendance-marking-title{font-size:24px}.attendance-marking-sessions-grid{gap:15px}}@media (width<=768px){.attendance-marking-container{padding:10px}.attendance-marking-sessions-grid{grid-template-columns:1fr;gap:15px}.attendance-marking-session-card{padding:15px}.attendance-marking-session-title{font-size:16px}.attendance-marking-session-detail{font-size:13px}.attendance-marking-mark-btn{padding:10px 15px;font-size:14px}.attendance-marking-title{margin-bottom:15px;font-size:22px}.attendance-marking-no-sessions{padding:40px 15px}.attendance-marking-no-sessions-title{font-size:16px}.attendance-marking-no-sessions-subtitle{font-size:14px}}@media (width<=480px){.attendance-marking-container{padding:8px}.attendance-marking-session-card{padding:12px}.attendance-marking-session-title{font-size:14px}.attendance-marking-session-detail{margin:5px 0;font-size:12px}.attendance-marking-mark-btn{padding:8px 12px;font-size:13px}.attendance-marking-active-badge{padding:2px 8px;font-size:10px}.attendance-marking-title{font-size:20px}}@media print{.attendance-marking-mark-btn{display:none}.attendance-marking-session-card{break-inside:avoid;page-break-inside:avoid;box-shadow:none;border:1px solid #ddd}.attendance-marking-active-badge{color:#333;background:0 0;border:1px solid #ddd;animation:none}}@media (width>=1024px){.student-sidebar{transform:translate(0)!important}.student-floating-toggle{display:none}.student-main-content{width:calc(100% - 280px);margin-left:280px}}@media (width>=769px) and (width<=1023px){.student-sidebar{width:260px}.student-sidebar.closed{transform:translate(-260px)}.student-sidebar.open{transform:translate(0)}.student-floating-toggle{display:flex}.student-main-content{width:100%}.student-main-content.sidebar-open{width:calc(100% - 260px);margin-left:260px}.student-main-content.sidebar-closed{width:100%;margin-left:0}}@media (width<=768px){.student-floating-toggle{display:flex}.student-sidebar{z-index:1200;width:280px}.student-sidebar.closed{transform:translate(-280px)}.student-sidebar.open{transform:translate(0);box-shadow:2px 0 30px #0000004d}.student-main-content{width:100%}.student-main-content.sidebar-open{opacity:.9;margin-left:0}.student-main-content.sidebar-closed{margin-left:0}.student-sidebar-overlay{z-index:1199;background:#00000080;animation:.3s studentFadeIn;position:fixed;inset:0}@keyframes studentFadeIn{0%{opacity:0}to{opacity:1}}.student-dashboard-header{padding:var(--spacing-lg)}.student-tab-content{padding:0 var(--spacing-md) var(--spacing-md)}.student-dashboard-header h1{font-size:24px}}@media (width<=480px){.student-dashboard-header{padding:var(--spacing-md)}.student-dashboard-header h1{font-size:20px}.student-dashboard-header p{font-size:14px}.student-tab-content{padding:0 var(--spacing-sm) var(--spacing-sm)}}.teacher-attendance-control-container{max-width:1200px;margin:0 auto;padding:20px}.teacher-attendance-control-title{color:#333;margin-bottom:20px;font-size:28px}.teacher-attendance-control-course-selector{margin-bottom:30px}.teacher-attendance-control-course-select{cursor:pointer;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;width:100%;max-width:400px;padding:12px;font-size:16px;transition:all .3s}.teacher-attendance-control-course-select:focus{border-color:#4caf50;outline:none;box-shadow:0 0 0 3px #4caf501a}.teacher-attendance-control-container-grid{grid-template-columns:1fr 1.5fr;gap:30px;display:grid}.teacher-attendance-control-create-session,.teacher-attendance-control-sessions-list{background:#fff;border-radius:10px;padding:20px;box-shadow:0 2px 10px #0000001a}.teacher-attendance-control-section-title{color:#333;border-bottom:2px solid #4caf50;margin-top:0;margin-bottom:20px;padding-bottom:10px;font-size:20px}.teacher-attendance-control-form{flex-direction:column;gap:20px;display:flex}.teacher-attendance-control-form-group{margin-bottom:0}.teacher-attendance-control-label{color:#555;margin-bottom:8px;font-size:14px;font-weight:500;display:block}.teacher-attendance-control-input,.teacher-attendance-control-select{border:1px solid #ddd;border-radius:5px;width:100%;padding:10px;font-size:14px;transition:all .3s}.teacher-attendance-control-input:focus,.teacher-attendance-control-select:focus{border-color:#4caf50;outline:none;box-shadow:0 0 0 3px #4caf501a}.teacher-attendance-control-hint{color:#888;margin-top:5px;font-size:12px;display:block}.teacher-attendance-control-create-btn{color:#fff;cursor:pointer;background-color:#4caf50;border:none;border-radius:5px;width:100%;padding:12px 24px;font-size:16px;font-weight:700;transition:all .3s}.teacher-attendance-control-create-btn:hover{background-color:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.teacher-attendance-control-create-btn:active{transform:translateY(0)}.teacher-attendance-control-sessions-grid{flex-direction:column;gap:15px;max-height:500px;padding-right:5px;display:flex;overflow-y:auto}.teacher-attendance-control-session-item{border:1px solid #e0e0e0;border-radius:8px;padding:15px;transition:all .3s;animation:.3s teacherAttendanceControlFadeIn}.teacher-attendance-control-session-item:hover{transform:translate(5px);box-shadow:0 4px 12px #0000001a}.teacher-attendance-control-session-active{background-color:#f9fff9;border-left:4px solid #4caf50}.teacher-attendance-control-session-closed{opacity:.85;background-color:#fff9f9;border-left:4px solid #f44336}.teacher-attendance-control-session-info{margin-bottom:12px}.teacher-attendance-control-session-detail{color:#555;margin:5px 0;font-size:14px}.teacher-attendance-control-session-detail strong{color:#333;margin-right:5px}.teacher-attendance-control-close-btn{color:#fff;cursor:pointer;background-color:#f44336;border:none;border-radius:5px;width:100%;padding:8px 16px;font-size:14px;transition:all .3s}.teacher-attendance-control-close-btn:hover{background-color:#da190b;transform:scale(1.02);box-shadow:0 2px 8px #f443364d}.teacher-attendance-control-loading{text-align:center;color:#666;padding:50px;font-size:18px}.teacher-attendance-control-no-sessions{text-align:center;color:#999;padding:40px;font-style:italic}.teacher-attendance-control-sessions-grid::-webkit-scrollbar{width:8px}.teacher-attendance-control-sessions-grid::-webkit-scrollbar-track{background:#f1f1f1;border-radius:10px}.teacher-attendance-control-sessions-grid::-webkit-scrollbar-thumb{background:#888;border-radius:10px}.teacher-attendance-control-sessions-grid::-webkit-scrollbar-thumb:hover{background:#555}@keyframes teacherAttendanceControlFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=1023px){.teacher-attendance-control-container-grid{gap:20px}.teacher-attendance-control-title{font-size:24px}}@media (width<=768px){.teacher-attendance-control-container{padding:10px}.teacher-attendance-control-container-grid{grid-template-columns:1fr;gap:20px}.teacher-attendance-control-create-session,.teacher-attendance-control-sessions-list{padding:15px}.teacher-attendance-control-course-select{max-width:100%;padding:10px;font-size:14px}.teacher-attendance-control-section-title{font-size:18px}.teacher-attendance-control-session-detail,.teacher-attendance-control-session-detail strong{font-size:12px}.teacher-attendance-control-create-btn{padding:10px 20px;font-size:14px}.teacher-attendance-control-close-btn{padding:6px 12px;font-size:12px}.teacher-attendance-control-label{font-size:12px}.teacher-attendance-control-input,.teacher-attendance-control-select{padding:8px;font-size:12px}.teacher-attendance-control-hint{font-size:10px}}@media (width<=480px){.teacher-attendance-control-title{margin-bottom:15px;font-size:20px}.teacher-attendance-control-course-selector{margin-bottom:20px}.teacher-attendance-control-session-item{padding:10px}.teacher-attendance-control-sessions-grid{max-height:400px}.teacher-attendance-control-session-detail{margin:3px 0;font-size:11px}.teacher-attendance-control-create-session,.teacher-attendance-control-sessions-list{padding:12px}.teacher-attendance-control-section-title{margin-bottom:15px;font-size:16px}}@media print{.teacher-attendance-control-create-btn,.teacher-attendance-control-close-btn{display:none}.teacher-attendance-control-container{padding:0}.teacher-attendance-control-session-item{break-inside:avoid;page-break-inside:avoid}}:root{--spacing-xs:4px;--spacing-sm:8px;--spacing-md:16px;--spacing-lg:24px;--spacing-xl:32px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 2px 8px #00000014;--shadow-md:0 4px 16px #0000001a;--primary-color:#667eea;--primary-dark:#5a67d8;--gray-100:#f7fafc;--gray-200:#edf2f7;--gray-300:#e2e8f0;--gray-600:#718096;--gray-700:#4a5568;--gray-800:#2d3748;--gray-900:#1a202c;--white:#fff;--success-color:#48bb78;--warning-color:#ed8936;--error-color:#f56565}.grading-view-container{padding:var(--spacing-xl);max-width:1400px;margin:0 auto}.grading-view-header{margin-bottom:var(--spacing-xl);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.grading-view-back-btn{background:var(--gray-200);border-radius:var(--radius-md);cursor:pointer;border:none;padding:10px 20px;font-size:14px;transition:all .2s}.grading-view-back-btn:hover{background:var(--gray-300);transform:translate(-2px)}.grading-view-header-center{text-align:center;flex:1}.grading-view-header h2{color:var(--gray-900);margin:0;font-size:clamp(1.5rem,4vw,2rem)}.grading-view-assignment-info{color:var(--gray-600);margin-top:var(--spacing-xs);font-size:14px}.grading-view-header-right{width:80px}.grading-view-tabs{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);border-bottom:2px solid var(--gray-200);padding-bottom:var(--spacing-sm);display:flex}.grading-view-tab-btn{padding:var(--spacing-sm) var(--spacing-lg);cursor:pointer;color:var(--gray-600);border-radius:var(--radius-md);background:0 0;border:none;font-size:16px;font-weight:500;transition:all .2s}.grading-view-tab-btn:hover{color:var(--primary-color);background:var(--gray-100)}.grading-view-tab-btn.active{color:var(--primary-color);background:#667eea1a;position:relative}.grading-view-tab-btn.active:after{content:"";background:var(--primary-color);height:2px;position:absolute;bottom:-3px;left:0;right:0}.grading-view-message-banner{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);animation:.3s gradingViewSlideDown}.grading-view-message-success{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.grading-view-message-error{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.grading-view-submissions-stats{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);grid-template-columns:repeat(3,1fr);display:grid}.grading-view-stat-card{background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm)}.grading-view-stat-value{color:var(--primary-color);font-size:clamp(28px,5vw,40px);font-weight:700}.grading-view-stat-label{color:var(--gray-600);margin-top:var(--spacing-xs);font-size:14px}.grading-view-filters-section{gap:var(--spacing-lg);margin-bottom:var(--spacing-xl);background:var(--gray-100);padding:var(--spacing-lg);border-radius:var(--radius-lg);flex-wrap:wrap;display:flex}.grading-view-filter-group{flex:1;min-width:200px}.grading-view-filter-group label{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-size:14px;font-weight:500;display:block}.grading-view-filter-group select{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;font-size:14px}.grading-view-filter-group select:disabled{background:var(--gray-200);cursor:not-allowed}.grading-view-submissions-grid{gap:var(--spacing-lg);flex-direction:column;display:flex}.grading-view-submission-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border-left:4px solid var(--gray-400);transition:transform .2s,box-shadow .2s;overflow:hidden}.grading-view-submission-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.grading-view-submission-graded{border-left-color:var(--success-color)}.grading-view-submission-pending{border-left-color:var(--warning-color)}.grading-view-submission-late{border-left-color:var(--error-color)}.grading-view-submission-submitted{border-left-color:var(--warning-color)}.grading-view-submission-header{padding:var(--spacing-lg);background:var(--gray-100);border-bottom:1px solid var(--gray-200);justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.grading-view-student-info{align-items:center;gap:var(--spacing-md);display:flex}.grading-view-student-avatar{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:20px;font-weight:700;display:flex}.grading-view-student-details h4{color:var(--gray-900);margin:0;font-size:16px}.grading-view-student-details span{color:var(--gray-600);font-size:13px}.grading-view-assignment-badge{background:var(--primary-color);color:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.grading-view-late-badge{background:var(--error-color);color:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.grading-view-on-time-badge{background:var(--success-color);color:#fff;border-radius:20px;padding:4px 12px;font-size:12px;font-weight:600}.grading-view-submission-body{padding:var(--spacing-lg)}.grading-view-course-info{margin-bottom:var(--spacing-md)}.grading-view-course-badge{background:var(--gray-200);color:var(--gray-700);border-radius:20px;padding:4px 12px;font-size:12px;font-weight:500}.grading-view-submission-meta{gap:var(--spacing-lg);margin-bottom:var(--spacing-lg);flex-wrap:wrap;display:flex}.grading-view-meta-item{color:var(--gray-700);font-size:14px}.grading-view-submission-file-section{background:var(--gray-100);border-radius:var(--radius-md);padding:var(--spacing-md);margin-bottom:var(--spacing-lg);align-items:center;gap:var(--spacing-md);flex-wrap:wrap;display:flex}.grading-view-file-badge{color:#fff;border-radius:20px;padding:6px 12px;font-size:12px;font-weight:600}.grading-view-file-info{justify-content:space-between;align-items:center;gap:var(--spacing-md);flex-wrap:wrap;flex:1;display:flex}.grading-view-file-name{color:var(--gray-700);word-break:break-all;font-size:13px}.grading-view-file-actions{gap:var(--spacing-md);display:flex}.grading-view-download-link,.grading-view-preview-link{color:var(--primary-color);cursor:pointer;background:0 0;border:none;font-size:13px;text-decoration:none}.grading-view-download-link:hover,.grading-view-preview-link:hover{text-decoration:underline}.grading-view-grading-section{border-top:1px solid var(--gray-200);padding-top:var(--spacing-lg)}.grading-view-grade-input-group,.grading-view-feedback-input-group{margin-bottom:var(--spacing-md)}.grading-view-grade-input-group label,.grading-view-feedback-input-group label{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-size:14px;font-weight:500;display:block}.grading-view-grade-input{border:1px solid var(--gray-300);border-radius:var(--radius-sm);width:200px;padding:10px 12px;font-size:14px}@media (width<=768px){.grading-view-grade-input{width:100%}}.grading-view-grade-input.grading-view-has-grade{border-color:var(--success-color);background:#f0fff0}.grading-view-grade-preview{margin-left:var(--spacing-sm);font-size:13px;font-weight:600}.grading-view-feedback-input{border:1px solid var(--gray-300);border-radius:var(--radius-sm);resize:vertical;width:100%;padding:10px 12px;font-size:14px}.grading-view-grade-submit-btn{background:var(--primary-color);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;padding:10px 20px;font-size:14px;transition:all .2s}.grading-view-grade-submit-btn.grading-view-update{background:var(--warning-color)}.grading-view-grade-submit-btn:hover{filter:brightness(1.05);transform:translateY(-1px)}.grading-view-no-submissions{text-align:center;background:var(--gray-100);border-radius:var(--radius-lg);color:var(--gray-600);padding:60px 20px}.grading-view-preview-modal-overlay{z-index:2000;background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.grading-view-preview-modal-content{background:#fff;border-radius:12px;flex-direction:column;width:90%;max-width:900px;max-height:90vh;display:flex}.grading-view-preview-header{border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.grading-view-close-preview{cursor:pointer;background:0 0;border:none;font-size:24px}.grading-view-preview-body{flex:1;justify-content:center;align-items:center;min-height:400px;padding:20px;display:flex;overflow:auto}.grading-view-preview-image{object-fit:contain;max-width:100%;max-height:70vh}.grading-view-preview-pdf{border:none;width:100%;height:70vh}.grading-view-loading-container{flex-direction:column;justify-content:center;align-items:center;min-height:400px;display:flex}.grading-view-spinner{border:4px solid var(--gray-300);border-top-color:var(--primary-color);border-radius:50%;width:50px;height:50px;animation:1s linear infinite gradingViewSpin}@keyframes gradingViewSpin{to{transform:rotate(360deg)}}@keyframes gradingViewSlideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.grading-view-date-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-sm);background:#fff;font-size:14px}.grading-view-date-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.grading-view-filter-actions{align-items:flex-end;display:flex}.grading-view-clear-filters-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--gray-200);border-radius:var(--radius-sm);cursor:pointer;color:var(--gray-700);border:none;font-size:14px;font-weight:500;transition:all .2s}.grading-view-clear-filters-btn:hover{background:var(--gray-300);transform:translateY(-1px)}.grading-view-date-badge{color:#fff;margin-right:var(--spacing-sm);background:#ff9800;border-radius:20px;padding:4px 12px;font-size:11px;font-weight:600}.grading-view-submission-status{gap:var(--spacing-sm);flex-wrap:wrap;align-items:center;display:flex}@media (width<=768px){.grading-view-filter-actions{align-items:stretch}.grading-view-clear-filters-btn{margin-top:var(--spacing-sm)}.grading-view-date-badge{padding:2px 8px;font-size:10px}.grading-view-container{padding:var(--spacing-md)}.grading-view-header{text-align:center;flex-direction:column}.grading-view-back-btn{align-self:flex-start}.grading-view-submissions-stats{gap:var(--spacing-md)}.grading-view-submission-header{flex-direction:column;align-items:flex-start}.grading-view-submission-status{align-self:flex-end}.grading-view-file-info{width:100%}.grading-view-file-actions{justify-content:flex-start;width:100%}.grading-view-tabs{gap:var(--spacing-sm)}.grading-view-tab-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:14px}.grading-view-filters-section{gap:var(--spacing-md);flex-direction:column}.grading-view-filter-group{width:100%}}@media (width>=1024px){.teacher-sidebar{transform:translate(0)!important}.teacher-floating-toggle{display:none}.teacher-main-content{width:calc(100% - 280px);margin-left:280px}}@media (width>=769px) and (width<=1023px){.teacher-sidebar{width:260px}.teacher-sidebar.closed{transform:translate(-260px)}.teacher-sidebar.open{transform:translate(0)}.teacher-floating-toggle{display:flex}.teacher-main-content{width:100%}.teacher-main-content.sidebar-open{width:calc(100% - 260px);margin-left:260px}.teacher-main-content.sidebar-closed{width:100%;margin-left:0}}@media (width<=768px){.teacher-floating-toggle{display:flex}.teacher-sidebar{z-index:1200;width:280px}.teacher-sidebar.closed{transform:translate(-280px)}.teacher-sidebar.open{transform:translate(0);box-shadow:2px 0 30px #0000004d}.teacher-main-content{width:100%}.teacher-main-content.sidebar-open{opacity:.95;margin-left:0}.teacher-main-content.sidebar-closed{margin-left:0}.teacher-sidebar-overlay{z-index:1199;background:#00000080;animation:.3s teacherFadeIn;position:fixed;inset:0}@keyframes teacherFadeIn{0%{opacity:0}to{opacity:1}}.teacher-dashboard-header{padding:var(--spacing-lg)}.teacher-tab-content{padding:0 var(--spacing-md) var(--spacing-md)}.teacher-dashboard-header h1{font-size:24px}}@media (width<=480px){.teacher-dashboard-header{padding:var(--spacing-md)}.teacher-dashboard-header h1{font-size:20px}.teacher-dashboard-header p{font-size:14px}.teacher-tab-content{padding:0 var(--spacing-sm) var(--spacing-sm)}}@keyframes profileSlideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes profileSpin{to{transform:rotate(360deg)}}@media (width<=1023px){.profile-container{padding:var(--spacing-lg)}.profile-info-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (width<=640px){.profile-enrollment-section{padding:var(--spacing-md);margin:var(--spacing-lg) 0}.profile-course-item{padding:var(--spacing-sm)}.profile-course-name{font-size:var(--font-size-sm)}.profile-enroll-link-btn,.profile-enroll-more-btn{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.profile-container{padding:var(--spacing-md)}.profile-card-header{padding:var(--spacing-lg)}.profile-avatar{width:80px;height:80px;margin-bottom:var(--spacing-md)}.profile-avatar-text{font-size:36px}.profile-content,.profile-edit-form{padding:var(--spacing-lg)}.profile-info-grid{gap:var(--spacing-md);margin:var(--spacing-lg) 0;grid-template-columns:1fr}.profile-info-item{padding:var(--spacing-sm)}.profile-form-actions{gap:var(--spacing-sm);flex-direction:column}.profile-btn-primary,.profile-btn-outline,.profile-edit-btn{padding:var(--spacing-sm)}}@media (width<=480px){.profile-enrollment-section h3{font-size:var(--font-size-md)}.profile-course-code{font-size:var(--font-size-xs)}.profile-no-courses{padding:var(--spacing-lg)}.profile-container{padding:var(--spacing-sm)}.profile-card-header{padding:var(--spacing-md)}.profile-avatar{width:60px;height:60px}.profile-avatar-text{font-size:28px}.profile-name{font-size:1.25rem}.profile-role{font-size:var(--font-size-sm)}.profile-content,.profile-edit-form{padding:var(--spacing-md)}.profile-info-section h3{font-size:var(--font-size-lg)}.profile-info-item label{font-size:var(--font-size-xs)}.profile-info-item p{font-size:var(--font-size-sm)}.profile-error-message,.profile-success-message{margin:var(--spacing-md) var(--spacing-md) 0;padding:var(--spacing-sm);font-size:var(--font-size-sm)}}@media print{.profile-container{padding:0}.profile-edit-btn,.profile-form-actions{display:none}.profile-card{box-shadow:none}.profile-card-header{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#333}}:root{--primary-color:#1976d2;--primary-dark:#1565c0;--primary-light:#42a5f5;--secondary-color:#dc004e;--secondary-dark:#c51162;--secondary-light:#ff4081;--success-color:#4caf50;--warning-color:#ff9800;--error-color:#f44336;--info-color:#2196f3;--white:#fff;--black:#000;--gray-50:#fafafa;--gray-100:#f5f5f5;--gray-200:#eee;--gray-300:#e0e0e0;--gray-400:#bdbdbd;--gray-500:#9e9e9e;--gray-600:#757575;--gray-700:#616161;--gray-800:#424242;--gray-900:#212121;--font-family:"Roboto", "Helvetica", "Arial", sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--radius-sm:4px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a;--shadow-xl:0 20px 25px -5px #0000001a;--transition-fast:.15s ease-in-out;--transition-base:.25s ease-in-out;--transition-slow:.35s ease-in-out}[data-theme=dark]{--primary-color:#90caf9;--primary-dark:#64b5f6;--white:#1e1e1e;--gray-100:#2c2c2c;--gray-200:#3d3d3d;--gray-800:#e0e0e0;--gray-900:#f5f5f5}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--gray-900);background-color:var(--gray-100);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.5}h1,h2,h3,h4,h5,h6{margin-bottom:var(--spacing-md);font-weight:600;line-height:1.2}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}p{margin-bottom:var(--spacing-md)}a{color:var(--primary-color);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-dark)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-200);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn var(--transition-base)}.container{max-width:1200px;padding:0 var(--spacing-lg);margin:0 auto}.text-center{text-align:center}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.app{flex-direction:column;min-height:100vh;display:flex}.main-content{flex:1}.navbar{background-color:var(--white);box-shadow:var(--shadow-sm);z-index:1000;width:100%;position:sticky;top:0}.navbar-container{max-width:1400px;padding:var(--spacing-md) var(--spacing-xl);justify-content:space-between;align-items:center;margin:0 auto;display:flex}.navbar-brand{align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-xl);transition:transform var(--transition-fast);font-weight:700;text-decoration:none;display:flex}.navbar-brand:hover{transform:scale(1.02)}.navbar-brand-icon{transition:transform var(--transition-fast);font-size:28px}.navbar-brand:hover .navbar-brand-icon{transform:rotate(-5deg)}.navbar-brand-text{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.navbar-mobile-toggle{cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:all var(--transition-fast);background:0 0;border:none;display:none}.navbar-mobile-toggle:hover{background-color:var(--gray-100)}.navbar-hamburger{color:var(--gray-700);font-size:24px;display:block}.navbar-links{gap:var(--spacing-md);align-items:center;display:flex}.navbar-link{padding:var(--spacing-sm) var(--spacing-md);color:var(--gray-700);transition:all var(--transition-fast);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);align-items:center;gap:var(--spacing-xs);background:0 0;border:none;font-family:inherit;font-weight:500;text-decoration:none;display:inline-flex}.navbar-link:hover{color:var(--primary-color);background-color:var(--gray-100);transform:translateY(-1px)}.navbar-link-primary{background-color:var(--primary-color);color:var(--white)}.navbar-link-primary:hover{background-color:var(--primary-dark);color:var(--white);transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.navbar-link-button{background:0 0}.navbar-link-logout{color:var(--error-color)}.navbar-link-logout:hover{color:var(--error-color);background-color:#f443361a;transform:translateY(-1px)}.navbar-links.active{display:flex}@media (width<=1023px){.navbar-container{padding:var(--spacing-md) var(--spacing-lg)}.navbar-brand-text{font-size:var(--font-size-lg)}.navbar-brand-icon{font-size:24px}}@media (width<=768px){.navbar-mobile-toggle{display:block}.navbar-links{background-color:var(--white);padding:var(--spacing-md);box-shadow:var(--shadow-md);gap:var(--spacing-xs);flex-direction:column;animation:.3s navbarSlideDown;display:none;position:absolute;top:100%;left:0;right:0}@keyframes navbarSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.navbar-links.active{display:flex}.navbar-link{text-align:center;width:100%;padding:var(--spacing-md);justify-content:center}.navbar-container{padding:var(--spacing-sm) var(--spacing-md)}.navbar-brand-text{font-size:var(--font-size-md)}.navbar-brand-icon{font-size:20px}}@media (width<=480px){.navbar-container{padding:var(--spacing-sm) var(--spacing-md)}.navbar-brand-text{font-size:var(--font-size-sm)}.navbar-brand-icon{font-size:18px}.navbar-hamburger{font-size:20px}.navbar-link{padding:var(--spacing-sm);font-size:var(--font-size-sm)}}@media (width<=768px){body.navbar-menu-open{overflow:hidden}}.private-route{animation:fadeIn var(--transition-base)}.loader-container{justify-content:center;align-items:center;gap:var(--spacing-md);flex-direction:column;min-height:100vh;display:flex}.loader{border:4px solid var(--gray-300);border-top-color:var(--primary-color);border-radius:50%;width:48px;height:48px;animation:.8s linear infinite spin}.loader-text{color:var(--gray-600);font-size:var(--font-size-sm)}.homepage{overflow-x:hidden}.hero-section{background:linear-gradient(135deg, var(--primary-color) 0%, var(--primary-dark) 100%);color:var(--white);padding:var(--spacing-3xl) 0;text-align:center;position:relative}.hero-overlay{opacity:.1;background:url("data:image/svg+xml,<svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 1440 320\"><path fill=\"rgba(255,255,255,0.1)\" d=\"M0,96L48,112C96,128,192,160,288,160C384,160,480,128,576,122.7C672,117,768,139,864,154.7C960,171,1056,181,1152,165.3C1248,149,1344,107,1392,85.3L1440,64L1440,320L1392,320C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320L0,320Z\"></path></svg>") bottom/cover no-repeat;position:absolute;inset:0}.hero-title{font-size:var(--font-size-4xl);margin-bottom:var(--spacing-lg);z-index:1;font-weight:700;position:relative}.hero-subtitle{font-size:var(--font-size-xl);margin-bottom:var(--spacing-xl);opacity:.9;z-index:1;position:relative}.hero-buttons{gap:var(--spacing-md);z-index:1;justify-content:center;display:flex;position:relative}.features-section{padding:var(--spacing-3xl) 0;background-color:var(--white)}.section-title{text-align:center;font-size:var(--font-size-3xl);margin-bottom:var(--spacing-md);color:var(--gray-900)}.section-subtitle{text-align:center;color:var(--gray-600);margin-bottom:var(--spacing-2xl)}.features-grid{gap:var(--spacing-xl);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.feature-card{text-align:center;padding:var(--spacing-xl);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition-base), box-shadow var(--transition-base)}.feature-card:hover{box-shadow:var(--shadow-xl);transform:translateY(-8px)}.feature-icon{margin-bottom:var(--spacing-md);font-size:48px}.feature-title{font-size:var(--font-size-lg);margin-bottom:var(--spacing-sm);color:var(--gray-900);font-weight:600}.feature-description{color:var(--gray-600);font-size:var(--font-size-sm);line-height:1.6}.stats-section{background:linear-gradient(135deg, var(--gray-100) 0%, var(--gray-200) 100%);padding:var(--spacing-2xl) 0}.stats-grid{gap:var(--spacing-xl);text-align:center;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.stat-number{font-size:var(--font-size-4xl);color:var(--primary-color);margin-bottom:var(--spacing-sm);font-weight:700}.stat-label{color:var(--gray-600);font-size:var(--font-size-lg)}@media (width<=768px){.hero-title{font-size:var(--font-size-3xl)}.hero-subtitle{font-size:var(--font-size-lg)}.hero-buttons{flex-direction:column;align-items:center}.features-grid{padding:0 var(--spacing-md);grid-template-columns:1fr}.stat-number{font-size:var(--font-size-3xl)}}.login-container{min-height:100vh;padding:var(--spacing-lg);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);flex-direction:column;justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.login-decoration{z-index:0;pointer-events:none;width:100%;height:100%;position:absolute;top:0;left:0;overflow:hidden}.login-circle{pointer-events:none;background:#ffffff1a;border-radius:50%;animation:20s ease-in-out infinite loginFloat;position:absolute}.login-circle-1{width:300px;height:300px;animation-delay:0s;top:-100px;right:-100px}.login-circle-2{width:200px;height:200px;animation-delay:5s;bottom:-50px;left:-50px}.login-circle-3{width:150px;height:150px;animation-delay:10s;top:50%;left:20%}.login-card{z-index:10;background:#fff;border-radius:24px;width:100%;max-width:480px;padding:48px 40px;animation:.5s ease-out loginSlideUp;position:relative;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:32px}.login-logo{justify-content:center;align-items:center;gap:8px;margin-bottom:24px;display:flex}.login-logo-icon{font-size:36px}.login-logo-text{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700}.login-title{color:#1a202c;margin-bottom:8px;font-size:28px;font-weight:700}.login-subtitle{color:#718096;font-size:14px}.login-error{color:#c53030;background:#fed7d7;border-radius:12px;align-items:center;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:14px;animation:.5s loginShake;display:flex}.login-error-icon{font-size:16px}.login-form{flex-direction:column;gap:20px;display:flex}.login-input-group{align-items:center;display:flex;position:relative}.login-input-icon{color:#a0aec0;pointer-events:none;justify-content:center;align-items:center;font-size:18px;display:flex;position:absolute;left:16px}.login-input{background:#fff;border:2px solid #e2e8f0;border-radius:12px;width:100%;padding:14px 16px 14px 48px;font-size:16px;transition:all .3s}.login-input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.login-input:disabled{cursor:not-allowed;background:#f7fafc}.login-password-toggle{cursor:pointer;color:#a0aec0;z-index:2;background:0 0;border:none;padding:0;font-size:18px;transition:color .3s;position:absolute;right:16px}.login-password-toggle:hover:not(:disabled){color:#667eea}.login-password-toggle:disabled{cursor:not-allowed}.login-options{z-index:10;justify-content:space-between;align-items:center;font-size:14px;display:flex;position:relative}.login-checkbox{cursor:pointer;color:#4a5568;z-index:10;align-items:center;gap:8px;display:flex;position:relative}.login-checkbox input{cursor:pointer;accent-color:#667eea;width:16px;height:16px}.login-checkbox span{-webkit-user-select:none;user-select:none;cursor:pointer}.login-forgot-link{color:#667eea;cursor:pointer;z-index:10;font-weight:500;text-decoration:none;transition:color .3s;display:inline-block;position:relative}.login-forgot-link:hover{color:#5a67d8;text-decoration:underline}.login-submit-btn{color:#fff;cursor:pointer;z-index:10;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:12px;justify-content:center;align-items:center;padding:14px;font-size:16px;font-weight:600;transition:all .3s;display:flex;position:relative;overflow:hidden}.login-submit-btn:before{content:"";background:linear-gradient(90deg,#0000,#fff3,#0000);width:100%;height:100%;transition:left .5s;position:absolute;top:0;left:-100%}.login-submit-btn:hover:not(:disabled):before{left:100%}.login-submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite loginSpin;display:inline-block}.login-footer{text-align:center;z-index:10;border-top:1px solid #e2e8f0;margin-top:32px;padding-top:24px;position:relative}.login-register-text{color:#4a5568;font-size:14px}.login-register-link{color:#667eea;cursor:pointer;z-index:10;font-weight:600;text-decoration:none;transition:color .3s;display:inline-block;position:relative}.login-register-link:hover{color:#5a67d8;text-decoration:underline}.login-footer-note{text-align:center;color:#fffc;z-index:1;margin-top:24px;font-size:12px;position:relative}@media (width<=640px){.login-container{padding:var(--spacing-md)}.login-card{padding:32px 24px}.login-title{font-size:24px}.login-logo-icon{font-size:28px}.login-logo-text{font-size:22px}.login-input{padding:12px 16px 12px 44px;font-size:14px}.login-input-icon{font-size:16px;left:14px}.login-options{font-size:12px}.login-submit-btn{padding:12px;font-size:14px}}@media (width<=480px){.login-card{padding:24px 20px}.login-title{font-size:22px}.login-subtitle{font-size:12px}.login-options{flex-direction:column;align-items:flex-start;gap:12px}}.register-container{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex;position:relative;overflow:hidden}.register-container:before{content:"";background:radial-gradient(circle,#ffffff1a 0%,#0000 70%);width:200%;height:200%;animation:20s ease-in-out infinite registerPulse;position:absolute;top:-50%;left:-50%}.register-card{z-index:1;background:#fff;border-radius:24px;width:100%;max-width:700px;padding:40px;animation:.5s ease-out registerSlideUp;position:relative;box-shadow:0 20px 60px #0000004d}.register-header{text-align:center;margin-bottom:32px}.register-logo{justify-content:center;align-items:center;gap:8px;margin-bottom:24px;display:flex}.register-logo-icon{font-size:36px}.register-logo-text{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:28px;font-weight:700}.register-title{color:#1a202c;margin-bottom:8px;font-size:28px;font-weight:700}.register-subtitle{color:#718096;font-size:14px}.register-error{color:#c53030;background:#fed7d7;border-radius:12px;align-items:center;gap:8px;margin-bottom:24px;padding:12px 16px;font-size:14px;animation:.5s registerShake;display:flex}.register-error-icon{font-size:16px}.register-step-indicator{justify-content:space-between;margin-bottom:32px;display:flex;position:relative}.register-step-indicator:before{content:"";z-index:0;background:#e2e8f0;height:2px;position:absolute;top:20px;left:0;right:0}.register-step{text-align:center;z-index:1;flex:1;position:relative}.register-step-number{color:#718096;background:#e2e8f0;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;margin:0 auto 8px;font-weight:700;transition:all .3s;display:flex}.register-step-active .register-step-number{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 12px #667eea66}.register-step-label{color:#718096;font-size:12px;font-weight:500}.register-step-active .register-step-label{color:#667eea}.register-form{margin-top:24px}.register-step-content{animation:.3s registerFadeIn}.register-form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.register-input,.register-select,.register-textarea{background:#fff;border:2px solid #e2e8f0;border-radius:12px;width:100%;padding:12px 16px;font-family:inherit;font-size:14px;transition:all .3s}.register-input:focus,.register-select:focus,.register-textarea:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.register-textarea{resize:vertical;min-height:80px}.register-phone-field{margin-bottom:16px}.register-phone-prefix{border:2px solid #e2e8f0;border-radius:12px;align-items:center;gap:0;transition:all .3s;display:flex;overflow:hidden}.register-phone-prefix:focus-within{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.register-phone-prefix-text{color:#4a5568;background:#f7fafc;border-right:1px solid #e2e8f0;padding:12px 16px;font-size:14px;font-weight:600}.register-phone-input{background:#fff;border:none;outline:none;flex:1;padding:12px 16px;font-size:14px}.register-input-error{border-color:#f44336!important}.register-phone-error{color:#c62828;background:#ffebee;border-radius:8px;align-items:center;gap:8px;margin-top:8px;padding:8px 12px;font-size:12px;animation:.3s registerShake;display:flex}.register-phone-hint{color:#a0aec0;margin-top:6px;font-size:11px}.register-password-field{margin-bottom:16px;position:relative}.register-password-field .register-input{padding-right:48px}.register-password-toggle{cursor:pointer;color:#a0aec0;background:0 0;border:none;padding:0;font-size:18px;transition:color .3s;position:absolute;top:50%;right:16px;transform:translateY(-50%)}.register-password-toggle:hover{color:#667eea}.register-password-hint{color:#718096;margin-top:8px;font-size:12px}.register-role-selector{grid-template-columns:1fr 1fr;gap:24px;margin:24px 0;display:grid}.register-role-card{text-align:center;cursor:pointer;background:#fff;border:2px solid #e2e8f0;border-radius:16px;padding:32px 24px;transition:all .3s}.register-role-card:hover{transform:translateY(-4px);box-shadow:0 10px 25px #0000001a}.register-role-selected{background:linear-gradient(135deg,#667eea0d 0%,#764ba20d 100%);border-color:#667eea}.register-role-icon{margin-bottom:16px;font-size:48px}.register-role-title{color:#1a202c;margin-bottom:8px;font-size:18px;font-weight:600}.register-role-description{color:#718096;font-size:12px}.register-info-box{color:#1976d2;background:#e3f2fd;border-radius:12px;align-items:center;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:13px;display:flex}.register-info-icon{font-size:16px}.register-hint-text{color:#a0aec0;text-align:center;margin-top:-8px;margin-bottom:16px;font-size:11px}.register-form-actions{gap:16px;margin-top:32px;display:flex}.register-btn{cursor:pointer;border:none;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px 24px;font-size:16px;font-weight:600;transition:all .3s;display:flex}.register-btn-primary{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.register-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 10px 25px #667eea66}.register-btn-outline{color:#4a5568;background:#f7fafc;border:1px solid #e2e8f0}.register-btn-outline:hover{background:#edf2f7;transform:translateY(-2px)}.register-btn:disabled{opacity:.6;cursor:not-allowed}.register-loading-courses{text-align:center;color:#718096;background:#f7fafc;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:16px;padding:12px}.register-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:20px;height:20px;animation:.6s linear infinite registerSpin;display:inline-block}.register-footer{text-align:center;border-top:1px solid #e2e8f0;margin-top:32px;padding-top:24px}.register-login-text{color:#4a5568;justify-content:center;align-items:center;gap:8px;font-size:14px;display:flex}.register-login-link{color:#667eea;cursor:pointer;background:0 0;border:none;font-size:14px;font-weight:600;transition:color .3s}.register-login-link:hover{color:#5a67d8;text-decoration:underline}@media (width<=640px){.register-card{padding:24px 20px}.register-title{font-size:24px}.register-logo-icon{font-size:28px}.register-logo-text{font-size:22px}.register-form-row{grid-template-columns:1fr;gap:0}.register-role-selector{grid-template-columns:1fr;gap:16px}.register-role-card{padding:20px}.register-step-label{font-size:10px}.register-form-actions{flex-direction:column}.register-btn{width:100%}.register-phone-prefix-text{padding:10px 12px;font-size:12px}.register-phone-input{padding:10px 12px}}@media (width<=480px){.register-card{padding:20px 16px}.register-title{font-size:22px}.register-step-number{width:32px;height:32px;font-size:14px}.register-step-indicator:before{top:16px}.register-phone-prefix-text{padding:8px 10px;font-size:11px}.register-phone-input{padding:8px 10px}}.forgot-container{min-height:calc(100vh - 64px);padding:var(--spacing-xl);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.forgot-container:before{content:"";background:radial-gradient(circle,#ffffff1a 0%,#0000 70%);width:200%;height:200%;animation:20s ease-in-out infinite forgotPulse;position:absolute;top:-50%;left:-50%}.forgot-card{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:480px;padding:var(--spacing-xl);box-shadow:var(--shadow-lg);z-index:1;transition:transform .3s,box-shadow .3s;position:relative}.forgot-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #00000026}.forgot-card-success{text-align:center}.forgot-header{text-align:center;margin-bottom:var(--spacing-xl)}.forgot-header-icon{margin-bottom:var(--spacing-md);font-size:48px}.forgot-title{color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:28px;font-weight:700}.forgot-subtitle{color:var(--gray-600);font-size:var(--font-size-md);line-height:1.5}.forgot-error{color:#c33;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);align-items:center;gap:var(--spacing-sm);background:#fee;border-left:4px solid #c33;animation:.5s forgotShake;display:flex}.forgot-error-icon{font-size:18px}.forgot-error-text{font-size:var(--font-size-sm);flex:1}.forgot-form{margin-bottom:var(--spacing-xl)}.forgot-form-group{margin-bottom:var(--spacing-lg)}.forgot-label{margin-bottom:var(--spacing-xs);color:var(--gray-700);font-weight:500;font-size:var(--font-size-sm);display:block}.forgot-input-wrapper{align-items:center;display:flex;position:relative}.forgot-input-icon{left:var(--spacing-md);color:var(--gray-400);pointer-events:none;font-size:18px;position:absolute}.forgot-input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 45px;border:2px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all var(--transition-fast);font-family:inherit}.forgot-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.forgot-input:hover:not(:focus){border-color:var(--gray-400)}.forgot-btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600;text-decoration:none;display:inline-flex}.forgot-btn-primary{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));color:var(--white)}.forgot-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.forgot-btn-primary:active:not(:disabled){transform:translateY(0)}.forgot-btn-primary:disabled{opacity:.6;cursor:not-allowed}.forgot-btn-block{width:100%}.forgot-spinner{border:2px solid #ffffff4d;border-top-color:var(--white);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite forgotSpin;display:inline-block}.forgot-back-link{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--gray-200)}.forgot-back-link-btn{color:var(--primary-color);font-size:var(--font-size-sm);transition:all var(--transition-fast);align-items:center;gap:var(--spacing-xs);font-weight:500;text-decoration:none;display:inline-flex}.forgot-back-link-btn:hover{color:var(--primary-dark);transform:translate(-2px)}.forgot-help{text-align:center;margin-top:var(--spacing-lg)}.forgot-help-text{font-size:var(--font-size-xs);color:var(--gray-500)}.forgot-help-link{color:var(--primary-color);font-weight:500;text-decoration:none}.forgot-help-link:hover{text-decoration:underline}.forgot-success-content{text-align:center;position:relative}.forgot-success-icon-bg{opacity:.1;z-index:0;font-size:80px;position:absolute;top:20px;left:50%;transform:translate(-50%)}.forgot-success-icon{margin-bottom:var(--spacing-lg);z-index:1;font-size:64px;animation:.5s forgotBounce;position:relative}.forgot-success-title{color:var(--gray-900);margin-bottom:var(--spacing-md);z-index:1;font-size:28px;font-weight:700;position:relative}.forgot-success-message{color:var(--gray-600);margin-bottom:var(--spacing-lg);font-size:var(--font-size-md);z-index:1;position:relative}.forgot-success-instructions{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-xl);z-index:1;background:#f0f8ff;position:relative}.forgot-success-instructions p{font-size:var(--font-size-sm);color:var(--gray-700);margin:0}.forgot-success-note{margin-top:var(--spacing-xs)!important;font-size:var(--font-size-xs)!important;color:var(--gray-500)!important}.forgot-modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;justify-content:center;align-items:center;animation:.3s forgotFadeIn;display:flex;position:fixed;inset:0}.forgot-modal{background:var(--white);border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:90vh;animation:.3s forgotModalSlideUp;position:relative;overflow-y:auto}.forgot-modal-close{top:var(--spacing-md);right:var(--spacing-md);background:var(--gray-200);cursor:pointer;width:32px;height:32px;transition:all var(--transition-fast);color:var(--gray-600);border:none;border-radius:50%;justify-content:center;align-items:center;font-size:24px;display:flex;position:absolute}.forgot-modal-close:hover{background:var(--gray-300);transform:rotate(90deg)}.forgot-modal-icon{text-align:center;padding:var(--spacing-xl) var(--spacing-xl) 0;font-size:48px}.forgot-modal-title{text-align:center;color:var(--gray-900);margin:var(--spacing-md) 0;font-size:24px;font-weight:700}.forgot-modal-content{padding:0 var(--spacing-xl) var(--spacing-xl)}.forgot-support-message{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);text-align:center;border-left:4px solid var(--primary-color);background:linear-gradient(135deg,#667eea10 0%,#764ba210 100%)}.forgot-support-message p{margin:var(--spacing-xs) 0;font-size:var(--font-size-sm)}.forgot-support-reminder{color:var(--primary-color);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-sm);background:#fff3e0;display:inline-block;font-size:var(--font-size-xs)!important;margin-top:var(--spacing-xs)!important}.forgot-contact-options{gap:var(--spacing-md);margin-bottom:var(--spacing-xl);flex-direction:column;display:flex}.forgot-contact-option{align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-md);color:var(--gray-900);transition:all var(--transition-fast);border:2px solid #0000;text-decoration:none;display:flex}.forgot-contact-option:hover{background:var(--white);border-color:var(--primary-color);box-shadow:var(--shadow-sm);transform:translate(4px)}.forgot-contact-icon{text-align:center;min-width:40px;font-size:28px}.forgot-contact-option div{flex:1}.forgot-contact-option strong{font-size:var(--font-size-md);margin-bottom:4px;display:block}.forgot-contact-option small{font-size:var(--font-size-xs);color:var(--gray-600)}.forgot-contact-link{cursor:pointer;text-align:left;background:linear-gradient(135deg,#667eea10 0%,#764ba210 100%);border:none;width:100%;font-family:inherit}.forgot-modal-footer{margin-top:var(--spacing-lg);justify-content:center;display:flex}.forgot-modal-btn{padding:var(--spacing-sm) var(--spacing-xl);background:var(--primary-color);color:var(--white);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;font-weight:600}.forgot-modal-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media (width<=640px){.forgot-modal-content{padding:0 var(--spacing-md) var(--spacing-md)}.forgot-modal-title{font-size:20px}.forgot-modal-icon{padding:var(--spacing-lg) var(--spacing-lg) 0;font-size:40px}.forgot-contact-option{padding:var(--spacing-sm)}.forgot-contact-icon{min-width:32px;font-size:24px}.forgot-contact-option strong{font-size:var(--font-size-sm)}.forgot-container{padding:var(--spacing-md)}.forgot-card{padding:var(--spacing-lg)}.forgot-title{font-size:24px}.forgot-subtitle{font-size:var(--font-size-sm)}.forgot-header-icon{font-size:40px}.forgot-success-title{font-size:24px}.forgot-success-icon{font-size:56px}.forgot-success-icon-bg{font-size:70px}}@media (width<=480px){.forgot-card{padding:var(--spacing-md)}.forgot-title{font-size:22px}.forgot-input{font-size:var(--font-size-sm)}.forgot-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}.forgot-success-title{font-size:22px}.forgot-success-icon{font-size:48px}}@media (prefers-color-scheme:dark){.forgot-card{background:#1a1a2e}.forgot-title,.forgot-success-title{color:#fff}.forgot-subtitle,.forgot-success-message{color:#a0aec0}.forgot-input{color:#fff;background:#2d2d44;border-color:#3d3d5c}.forgot-input:focus{border-color:var(--primary-color)}.forgot-back-link{border-top-color:#3d3d5c}}.reset-container{min-height:calc(100vh - 64px);padding:var(--spacing-xl);background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.reset-container:before{content:"";background:radial-gradient(circle,#ffffff1a 0%,#0000 70%);width:200%;height:200%;animation:20s ease-in-out infinite resetPulse;position:absolute;top:-50%;left:-50%}.animate-slide-up{animation:.5s ease-out resetSlideUp}.reset-card{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:480px;padding:var(--spacing-xl);box-shadow:var(--shadow-lg);z-index:1;transition:transform .3s,box-shadow .3s;position:relative}.reset-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #00000026}.reset-card-error,.reset-card-success{text-align:center}.reset-header{text-align:center;margin-bottom:var(--spacing-xl)}.reset-header-icon{margin-bottom:var(--spacing-md);font-size:48px}.reset-title{color:var(--gray-900);margin-bottom:var(--spacing-sm);font-size:28px;font-weight:700}.reset-subtitle{color:var(--gray-600);font-size:var(--font-size-md)}.reset-error{color:#c33;padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);align-items:center;gap:var(--spacing-sm);background:#fee;border-left:4px solid #c33;animation:.5s resetShake;display:flex}.reset-error-icon{font-size:18px}.reset-error-text{font-size:var(--font-size-sm);flex:1}.reset-form{margin-bottom:var(--spacing-xl)}.reset-form-group{margin-bottom:var(--spacing-lg)}.reset-label{margin-bottom:var(--spacing-xs);color:var(--gray-700);font-weight:500;font-size:var(--font-size-sm);display:block}.reset-password-field{align-items:center;display:flex;position:relative}.reset-input-icon{left:var(--spacing-md);color:var(--gray-400);pointer-events:none;z-index:1;font-size:18px;position:absolute}.reset-input{width:100%;padding:var(--spacing-md) var(--spacing-md) var(--spacing-md) 45px;border:2px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all var(--transition-fast);font-family:inherit}.reset-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.reset-input:hover:not(:focus){border-color:var(--gray-400)}.reset-password-toggle{right:var(--spacing-md);cursor:pointer;color:var(--gray-400);z-index:1;background:0 0;border:none;padding:0;font-size:18px;transition:color .3s;position:absolute}.reset-password-toggle:hover{color:var(--primary-color)}.reset-requirements{margin:var(--spacing-lg) 0;padding:var(--spacing-md);background:var(--gray-100);border-radius:var(--radius-md);border:1px solid var(--gray-200)}.reset-requirements-title{margin-bottom:var(--spacing-sm);color:var(--gray-700);font-weight:600;font-size:var(--font-size-sm)}.reset-requirements-list{margin:0;padding-left:0;list-style:none}.reset-requirements-list li{padding:var(--spacing-xs) 0;color:var(--gray-600);font-size:var(--font-size-sm);align-items:center;gap:var(--spacing-sm);transition:all .3s;display:flex}.reset-requirements-list li.valid{color:var(--success-color)}.reset-requirement-icon{width:20px;font-weight:700;display:inline-block}.reset-btn{justify-content:center;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-md);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:none;font-weight:600;text-decoration:none;display:inline-flex}.reset-btn-primary{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));color:var(--white)}.reset-btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.reset-btn-primary:active:not(:disabled){transform:translateY(0)}.reset-btn-primary:disabled{opacity:.6;cursor:not-allowed}.reset-btn-block{width:100%}.reset-spinner{border:2px solid #ffffff4d;border-top-color:var(--white);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite resetSpin;display:inline-block}.reset-back-link{text-align:center;margin-top:var(--spacing-lg);padding-top:var(--spacing-md);border-top:1px solid var(--gray-200)}.reset-back-link-btn{color:var(--primary-color);font-size:var(--font-size-sm);transition:all var(--transition-fast);align-items:center;gap:var(--spacing-xs);font-weight:500;text-decoration:none;display:inline-flex}.reset-back-link-btn:hover{color:var(--primary-dark);transform:translate(-2px)}.reset-error-content,.reset-success-content{text-align:center}.reset-error-icon,.reset-success-icon{margin-bottom:var(--spacing-lg);font-size:64px}.reset-error-icon{color:var(--error-color)}.reset-success-icon{color:var(--success-color);font-size:72px;font-weight:700}.reset-error-title,.reset-success-title{color:var(--gray-900);margin-bottom:var(--spacing-md);font-size:28px;font-weight:700}.reset-error-message,.reset-success-message{color:var(--gray-600);margin-bottom:var(--spacing-xl);font-size:var(--font-size-md)}.reset-progress-bar{background:var(--gray-200);width:100%;height:4px;margin:var(--spacing-lg) 0;border-radius:2px;overflow:hidden}.reset-progress-fill{background:linear-gradient(90deg, var(--primary-color), var(--primary-dark));border-radius:2px;height:100%;animation:3s linear forwards resetProgress}.reset-redirect-text{margin-top:var(--spacing-md);font-size:var(--font-size-sm);color:var(--gray-500)}@media (width<=640px){.reset-container{padding:var(--spacing-md)}.reset-card{padding:var(--spacing-lg)}.reset-title{font-size:24px}.reset-header-icon{font-size:40px}.reset-error-title,.reset-success-title{font-size:24px}.reset-error-icon,.reset-success-icon{font-size:56px}}@media (width<=480px){.reset-card{padding:var(--spacing-md)}.reset-title{font-size:22px}.reset-subtitle{font-size:var(--font-size-sm)}.reset-input{font-size:var(--font-size-sm);padding:var(--spacing-sm) var(--spacing-sm) var(--spacing-sm) 40px}.reset-input-icon{left:var(--spacing-sm);font-size:16px}.reset-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-sm)}.reset-requirements-list li{font-size:var(--font-size-xs)}.reset-error-title,.reset-success-title{font-size:22px}.reset-error-icon,.reset-success-icon{font-size:48px}}@media (prefers-color-scheme:dark){.reset-card{background:#1a1a2e}.reset-title,.reset-error-title,.reset-success-title{color:#fff}.reset-subtitle,.reset-error-message,.reset-success-message{color:#a0aec0}.reset-input{color:#fff;background:#2d2d44;border-color:#3d3d5c}.reset-input:focus{border-color:var(--primary-color)}.reset-requirements{background:#2d2d44;border-color:#3d3d5c}.reset-requirements-title{color:#e2e8f0}.reset-back-link{border-top-color:#3d3d5c}}.profile-container{max-width:800px;padding:var(--spacing-xl);justify-content:center;align-items:center;min-height:calc(100vh - 80px);margin:0 auto;display:flex}.profile-card{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;animation:.5s profileSlideUp;overflow:hidden}.profile-card-header{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));padding:var(--spacing-xl);text-align:center;color:var(--white)}.profile-avatar{background:var(--white);width:100px;height:100px;margin:0 auto var(--spacing-lg);border-radius:50%;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 15px #0003}.profile-avatar-text{color:var(--primary-color);font-size:48px;font-weight:700}.profile-name{margin-bottom:var(--spacing-xs);font-size:clamp(1.5rem,4vw,2rem)}.profile-role{opacity:.9;font-size:var(--font-size-lg)}.profile-error-message{margin:var(--spacing-lg) var(--spacing-xl) 0;padding:var(--spacing-md);color:#721c24;border-radius:var(--radius-md);background:#f8d7da;border:1px solid #f5c6cb}.profile-success-message{margin:var(--spacing-lg) var(--spacing-xl) 0;padding:var(--spacing-md);color:#155724;border-radius:var(--radius-md);background:#d4edda;border:1px solid #c3e6cb}.profile-content,.profile-edit-form{padding:var(--spacing-xl)}.profile-info-section h3{margin-bottom:var(--spacing-lg);color:var(--gray-900);border-bottom:2px solid var(--primary-color);padding-bottom:var(--spacing-sm);display:inline-block}.profile-info-grid{gap:var(--spacing-lg);margin:var(--spacing-xl) 0;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));display:grid}.profile-info-item{background:var(--gray-100);padding:var(--spacing-md);border-radius:var(--radius-md);transition:transform .2s,box-shadow .2s}.profile-info-item:hover{box-shadow:var(--shadow-sm);transform:translateY(-2px)}.profile-info-item label{font-size:var(--font-size-sm);color:var(--gray-600);margin-bottom:var(--spacing-xs);font-weight:500;display:block}.profile-info-item p{font-size:var(--font-size-md);color:var(--gray-900);word-break:break-word;margin:0;font-weight:600}.profile-edit-btn{width:100%;padding:var(--spacing-md);background:var(--primary-color);color:var(--white);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;font-weight:600}.profile-edit-btn:hover{background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.profile-edit-form h3{margin-bottom:var(--spacing-lg);color:var(--gray-900);font-size:var(--font-size-xl)}.profile-form-group{margin-bottom:var(--spacing-md)}.profile-form-input,.profile-form-textarea{width:100%;padding:var(--spacing-md);border:1px solid var(--gray-300);border-radius:var(--radius-md);font-size:var(--font-size-md);transition:all var(--transition-fast);font-family:inherit}.profile-form-input:focus,.profile-form-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px #667eea1a}.profile-form-textarea{resize:vertical;min-height:80px}.profile-form-actions{gap:var(--spacing-md);margin-top:var(--spacing-lg);display:flex}.profile-btn-primary,.profile-btn-outline{padding:var(--spacing-md);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;flex:1;font-weight:600}.profile-btn-primary{background:var(--primary-color);color:var(--white)}.profile-btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.profile-btn-primary:disabled{opacity:.6;cursor:not-allowed}.profile-btn-outline{background:var(--gray-200);color:var(--gray-700)}.profile-btn-outline:hover{background:var(--gray-300);transform:translateY(-2px)}.profile-loader-container{justify-content:center;align-items:center;min-height:400px;display:flex}.profile-loader{border:4px solid var(--gray-300);border-top-color:var(--primary-color);border-radius:50%;width:50px;height:50px;animation:1s linear infinite profileSpin}.profile-enrollment-section{margin:var(--spacing-xl) 0;padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--gray-200);background:linear-gradient(135deg,#f8f9fa 0%,#fff 100%)}.profile-enrollment-section h3{margin-bottom:var(--spacing-lg);color:var(--gray-900);font-size:var(--font-size-lg);align-items:center;gap:var(--spacing-sm);display:flex}.profile-courses-list{gap:var(--spacing-md);margin-bottom:var(--spacing-lg);flex-direction:column;display:flex}.profile-course-item{background:var(--white);padding:var(--spacing-md);border-radius:var(--radius-md);border-left:4px solid var(--primary-color);box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.profile-course-item:hover{box-shadow:var(--shadow-md);transform:translate(4px)}.profile-course-code{font-size:var(--font-size-sm);color:var(--primary-color);margin-bottom:var(--spacing-xs);font-weight:600}.profile-course-name{font-size:var(--font-size-md);color:var(--gray-900);margin-bottom:var(--spacing-xs);font-weight:600}.profile-course-date{font-size:var(--font-size-xs);color:var(--gray-500)}.profile-no-courses{text-align:center;padding:var(--spacing-xl);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);background:#fff3e0}.profile-no-courses p{color:#e65100;margin-bottom:var(--spacing-md)}.profile-enroll-link-btn,.profile-enroll-more-btn{width:100%;padding:var(--spacing-md);background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));color:var(--white);border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-md);transition:all var(--transition-fast);border:none;font-weight:600}.profile-enroll-link-btn:hover,.profile-enroll-more-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.profile-max-courses{text-align:center;padding:var(--spacing-md);color:#2e7d32;border-radius:var(--radius-md);background:#e8f5e9;font-weight:600}@media (width<=1023px){.profile-container{padding:var(--spacing-lg)}.profile-info-grid{gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}}@media (width<=640px){.profile-enrollment-section{padding:var(--spacing-md);margin:var(--spacing-lg) 0}.profile-course-item{padding:var(--spacing-sm)}.profile-course-name{font-size:var(--font-size-sm)}.profile-enroll-link-btn,.profile-enroll-more-btn{padding:var(--spacing-sm);font-size:var(--font-size-sm)}.profile-container{padding:var(--spacing-md)}.profile-card-header{padding:var(--spacing-lg)}.profile-avatar{width:80px;height:80px;margin-bottom:var(--spacing-md)}.profile-avatar-text{font-size:36px}.profile-content,.profile-edit-form{padding:var(--spacing-lg)}.profile-info-grid{gap:var(--spacing-md);margin:var(--spacing-lg) 0;grid-template-columns:1fr}.profile-info-item{padding:var(--spacing-sm)}.profile-form-actions{gap:var(--spacing-sm);flex-direction:column}.profile-btn-primary,.profile-btn-outline,.profile-edit-btn{padding:var(--spacing-sm)}}@media (width<=480px){.profile-enrollment-section h3{font-size:var(--font-size-md)}.profile-course-code{font-size:var(--font-size-xs)}.profile-no-courses{padding:var(--spacing-lg)}.profile-container{padding:var(--spacing-sm)}.profile-card-header{padding:var(--spacing-md)}.profile-avatar{width:60px;height:60px}.profile-avatar-text{font-size:28px}.profile-name{font-size:1.25rem}.profile-role{font-size:var(--font-size-sm)}.profile-content,.profile-edit-form{padding:var(--spacing-md)}.profile-info-section h3{font-size:var(--font-size-lg)}.profile-info-item label{font-size:var(--font-size-xs)}.profile-info-item p{font-size:var(--font-size-sm)}.profile-error-message,.profile-success-message{margin:var(--spacing-md) var(--spacing-md) 0;padding:var(--spacing-sm);font-size:var(--font-size-sm)}}@media print{.profile-container{padding:0}.profile-edit-btn,.profile-form-actions{display:none}.profile-card{box-shadow:none}.profile-card-header{-webkit-print-color-adjust:exact;print-color-adjust:exact;background:#333}}.student-dashboard{background:var(--gray-100);min-height:100vh;display:flex;position:relative}.student-sidebar{color:#fff;z-index:1000;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);width:280px;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;overflow:hidden auto;box-shadow:2px 0 20px #0000001a}.student-sidebar::-webkit-scrollbar{width:5px}.student-sidebar::-webkit-scrollbar-track{background:#ffffff1a}.student-sidebar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:5px}.student-sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff80}.student-sidebar.closed{transform:translate(-280px)}.student-sidebar.open{transform:translate(0)}.student-sidebar-header{text-align:center;border-bottom:1px solid #ffffff1a;margin-bottom:20px;padding:24px 20px}.student-sidebar-logo{justify-content:center;align-items:center;gap:10px;font-size:24px;font-weight:700;display:flex}.student-sidebar-logo span:first-child{font-size:28px}.student-sidebar-logo span:last-child{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.student-sidebar-subtitle{color:#fff9;margin-top:8px;font-size:12px}.student-sidebar-nav{padding:0 15px}.student-sidebar-nav-item{cursor:pointer;color:#ffffffb3;border-radius:12px;align-items:center;gap:12px;margin:5px 0;padding:12px 16px;font-size:15px;font-weight:500;transition:all .3s;display:flex}.student-sidebar-nav-item:hover{color:#fff;background:#ffffff1a;transform:translate(5px)}.student-sidebar-nav-item.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 15px #667eea4d}.student-nav-icon{text-align:center;width:28px;font-size:20px}.student-nav-text{flex:1}.student-floating-toggle{color:#fff;cursor:pointer;z-index:1100;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .3s;display:flex;position:fixed;top:20px;left:20px;box-shadow:0 4px 15px #0003}.student-floating-toggle:hover{transform:scale(1.05);box-shadow:0 6px 20px #667eea66}.student-floating-toggle.open{background:linear-gradient(135deg,#4caf50 0%,#45a049 100%);left:300px}.student-floating-toggle.closed{background:linear-gradient(135deg,#f44336 0%,#d32f2f 100%);left:20px}.student-toggle-arrow{font-size:20px;font-weight:700;transition:transform .3s;display:inline-block}.student-floating-toggle.open .student-toggle-arrow{transform:rotate(180deg)}.student-floating-toggle.closed .student-toggle-arrow{transform:rotate(0)}.student-main-content{flex:1;width:100%;min-height:100vh;transition:margin-left .3s}.student-dashboard-header{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));color:var(--white);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.student-dashboard-header h1{margin-bottom:var(--spacing-sm);font-size:clamp(1.5rem,4vw,2rem)}.student-dashboard-header p{opacity:.9}.student-tab-content{padding:0 var(--spacing-xl) var(--spacing-xl)}@media (width>=1024px){.student-sidebar{transform:translate(0)!important}.student-floating-toggle{display:none}.student-main-content{width:calc(100% - 280px);margin-left:280px}}@media (width>=769px) and (width<=1023px){.student-sidebar{width:260px}.student-sidebar.closed{transform:translate(-260px)}.student-sidebar.open{transform:translate(0)}.student-floating-toggle{display:flex}.student-main-content{width:100%}.student-main-content.sidebar-open{width:calc(100% - 260px);margin-left:260px}.student-main-content.sidebar-closed{width:100%;margin-left:0}}@media (width<=768px){.student-floating-toggle{display:flex}.student-sidebar{z-index:1200;width:280px}.student-sidebar.closed{transform:translate(-280px)}.student-sidebar.open{transform:translate(0);box-shadow:2px 0 30px #0000004d}.student-main-content{width:100%}.student-main-content.sidebar-open{opacity:.9;margin-left:0}.student-main-content.sidebar-closed{margin-left:0}.student-sidebar-overlay{z-index:1199;background:#00000080;animation:.3s studentFadeIn;position:fixed;inset:0}@keyframes studentFadeIn{0%{opacity:0}to{opacity:1}}.student-dashboard-header{padding:var(--spacing-lg)}.student-tab-content{padding:0 var(--spacing-md) var(--spacing-md)}.student-dashboard-header h1{font-size:24px}}@media (width<=480px){.student-dashboard-header{padding:var(--spacing-md)}.student-dashboard-header h1{font-size:20px}.student-dashboard-header p{font-size:14px}.student-tab-content{padding:0 var(--spacing-sm) var(--spacing-sm)}}.student-sidebar{scrollbar-width:thin}.student-tab-content>*{max-width:100%;overflow-x:auto}.teacher-dashboard{background:var(--gray-100);min-height:100vh;display:flex;position:relative}.teacher-sidebar{color:#fff;z-index:1000;background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);width:280px;height:100vh;transition:transform .3s cubic-bezier(.4,0,.2,1);position:fixed;top:0;left:0;overflow:hidden auto;box-shadow:2px 0 20px #0000001a}.teacher-sidebar::-webkit-scrollbar{width:5px}.teacher-sidebar::-webkit-scrollbar-track{background:#ffffff1a}.teacher-sidebar::-webkit-scrollbar-thumb{background:#ffffff4d;border-radius:5px}.teacher-sidebar::-webkit-scrollbar-thumb:hover{background:#ffffff80}.teacher-sidebar.closed{transform:translate(-280px)}.teacher-sidebar.open{transform:translate(0)}.teacher-sidebar-header{text-align:center;border-bottom:1px solid #ffffff1a;margin-bottom:20px;padding:24px 20px}.teacher-sidebar-logo{justify-content:center;align-items:center;gap:10px;font-size:24px;font-weight:700;display:flex}.teacher-sidebar-logo span:first-child{font-size:28px}.teacher-sidebar-logo span:last-child{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.teacher-sidebar-subtitle{color:#fff9;margin-top:8px;font-size:12px}.teacher-sidebar-nav{padding:0 15px}.teacher-sidebar-nav-item{cursor:pointer;color:#ffffffb3;border-radius:12px;align-items:center;gap:12px;margin:5px 0;padding:12px 16px;font-size:15px;font-weight:500;transition:all .3s;display:flex}.teacher-sidebar-nav-item:hover{color:#fff;background:#ffffff1a;transform:translate(5px)}.teacher-sidebar-nav-item.active{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);box-shadow:0 4px 15px #667eea4d}.teacher-nav-icon{text-align:center;width:28px;font-size:20px}.teacher-nav-text{flex:1}.teacher-floating-toggle{color:#fff;cursor:pointer;z-index:1100;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border:none;border-radius:50%;justify-content:center;align-items:center;width:50px;height:50px;transition:all .3s;display:flex;position:fixed;top:20px;left:20px;box-shadow:0 4px 15px #0003}.teacher-floating-toggle:hover{transform:scale(1.05);box-shadow:0 6px 20px #667eea66}.teacher-floating-toggle.open{background:linear-gradient(135deg,#4caf50 0%,#45a049 100%);left:300px}.teacher-floating-toggle.closed{background:linear-gradient(135deg,#f44336 0%,#d32f2f 100%);left:20px}.teacher-toggle-arrow{font-size:20px;font-weight:700;transition:transform .3s;display:inline-block}.teacher-floating-toggle.open .teacher-toggle-arrow{transform:rotate(180deg)}.teacher-floating-toggle.closed .teacher-toggle-arrow{transform:rotate(0)}.teacher-main-content{flex:1;width:100%;min-height:100vh;transition:margin-left .3s}.teacher-dashboard-header{background:linear-gradient(135deg, var(--primary-color), var(--primary-dark));color:var(--white);padding:var(--spacing-xl);margin-bottom:var(--spacing-xl)}.teacher-dashboard-header h1{margin-bottom:var(--spacing-sm);font-size:clamp(1.5rem,4vw,2rem)}.teacher-dashboard-header p{opacity:.9}.teacher-tab-content{padding:0 var(--spacing-xl) var(--spacing-xl)}@media (width>=1024px){.teacher-sidebar{transform:translate(0)!important}.teacher-floating-toggle{display:none}.teacher-main-content{width:calc(100% - 280px);margin-left:280px}}@media (width>=769px) and (width<=1023px){.teacher-sidebar{width:260px}.teacher-sidebar.closed{transform:translate(-260px)}.teacher-sidebar.open{transform:translate(0)}.teacher-floating-toggle{display:flex}.teacher-main-content{width:100%}.teacher-main-content.sidebar-open{width:calc(100% - 260px);margin-left:260px}.teacher-main-content.sidebar-closed{width:100%;margin-left:0}}@media (width<=768px){.teacher-floating-toggle{display:flex}.teacher-sidebar{z-index:1200;width:280px}.teacher-sidebar.closed{transform:translate(-280px)}.teacher-sidebar.open{transform:translate(0);box-shadow:2px 0 30px #0000004d}.teacher-main-content{width:100%}.teacher-main-content.sidebar-open{opacity:.95;margin-left:0}.teacher-main-content.sidebar-closed{margin-left:0}.teacher-sidebar-overlay{z-index:1199;background:#00000080;animation:.3s teacherFadeIn;position:fixed;inset:0}@keyframes teacherFadeIn{0%{opacity:0}to{opacity:1}}.teacher-dashboard-header{padding:var(--spacing-lg)}.teacher-tab-content{padding:0 var(--spacing-md) var(--spacing-md)}.teacher-dashboard-header h1{font-size:24px}}@media (width<=480px){.teacher-dashboard-header{padding:var(--spacing-md)}.teacher-dashboard-header h1{font-size:20px}.teacher-dashboard-header p{font-size:14px}.teacher-tab-content{padding:0 var(--spacing-sm) var(--spacing-sm)}}.teacher-sidebar{scrollbar-width:thin}.teacher-tab-content>*{max-width:100%;overflow-x:auto}
