:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f8f9fa}html,body{overflow-x:hidden;max-width:100vw}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.6;color:#1f2937;margin:0;padding:0;width:100%;overflow-x:hidden}.landing-page{min-height:100vh;width:100%;background:linear-gradient(135deg,#f0f9ff,#e0e7ff,#f3e8ff)}.seo-content{position:absolute;left:-10000px;width:1px;height:1px;overflow:hidden}.header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;width:100%}.header-container{width:100%;margin:0;padding:0 60px}.header-content{display:flex;justify-content:space-between;align-items:center;height:64px}.logo-section{display:flex;align-items:center;gap:12px}.logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:8px;display:flex;align-items:center;justify-content:center}.logo-icon svg{width:24px;height:24px;color:#fff}.logo-title{font-size:20px;font-weight:700;color:#1f2937;margin:0}.logo-subtitle{font-size:14px;color:#6b7280;margin:0}.header-buttons{display:flex;align-items:center;gap:12px}.btn-secondary{background:transparent;color:#2563eb;border:2px solid #2563eb;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer}.btn-secondary:hover{background:#2563eb;color:#fff}.btn-primary{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-weight:600;cursor:pointer}.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#6d28d9)}.container{width:100%;margin:0;padding:0 60px}.hero-section{padding:100px 0;text-align:center;min-height:calc(100vh - 64px);display:flex;align-items:center;width:100%}.hero-content{max-width:1000px;margin:0 auto;width:100%}.hero-title{font-size:64px;font-weight:700;color:#1f2937;margin-bottom:32px;line-height:1.1}.hero-title-gradient{display:block;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent}.hero-description{font-size:20px;color:#6b7280;margin-bottom:32px;line-height:1.6}.hero-buttons{display:flex;flex-direction:row;gap:24px;align-items:center;justify-content:center}.btn-hero-primary{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;padding:16px 32px;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;text-decoration:none}.btn-hero-primary:hover{background:linear-gradient(135deg,#1d4ed8,#6d28d9)}.btn-hero-secondary{background:transparent;color:#2563eb;border:2px solid #2563eb;padding:16px 32px;border-radius:12px;font-size:18px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block}.btn-hero-secondary:hover{background:#2563eb;color:#fff}.btn-icon{width:20px;height:20px}.features-section{background:#fff;padding:100px 0;width:100%}.section-header{text-align:center;margin-bottom:64px}.section-title{font-size:36px;font-weight:700;color:#1f2937;margin-bottom:16px}.section-description{font-size:20px;color:#6b7280;max-width:800px;margin:0 auto}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px}.feature-card{text-align:center;padding:32px 24px;border-radius:16px;transition:all .3s ease}.feature-card:nth-child(1){background:#eff6ff}.feature-card:nth-child(2){background:#faf5ff}.feature-card:nth-child(3){background:#f0fdf4}.feature-card:nth-child(4){background:#eef2ff}.feature-card:hover{transform:translateY(-4px);box-shadow:0 20px 25px -5px #0000001a}.feature-icon{width:64px;height:64px;border-radius:12px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.feature-icon.blue{background:#2563eb}.feature-icon.purple{background:#7c3aed}.feature-icon.green{background:#059669}.feature-icon.indigo{background:#4f46e5}.feature-icon svg{width:32px;height:32px;color:#fff}.feature-title{font-size:20px;font-weight:600;color:#1f2937;margin-bottom:8px}.feature-description{color:#6b7280;line-height:1.6}.about-section{background:#f9fafb;padding:100px 0;width:100%}.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}.about-title{font-size:36px;font-weight:700;color:#1f2937;margin-bottom:24px}.about-description{font-size:18px;color:#6b7280;margin-bottom:24px;line-height:1.6}.btn-about{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-weight:600;cursor:pointer}.btn-about:hover{background:linear-gradient(135deg,#1d4ed8,#6d28d9)}.about-visual{display:flex;justify-content:center}.about-card{background:linear-gradient(135deg,#dbeafe,#e0e7ff);border-radius:16px;padding:48px 32px;text-align:center;max-width:400px}.about-icon{width:128px;height:128px;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:50%;margin:0 auto 24px;display:flex;align-items:center;justify-content:center}.about-icon svg{width:64px;height:64px;color:#fff}.about-card-title{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:16px}.about-card-description{color:#6b7280;font-size:18px;line-height:1.6}.footer{background:#111827;color:#fff;padding:48px 0 24px;width:100%}.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:32px}.footer-logo{display:flex;align-items:center;gap:12px;margin-bottom:16px}.footer-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:8px;display:flex;align-items:center;justify-content:center}.footer-logo-icon svg{width:24px;height:24px;color:#fff}.footer-brand-title{font-size:18px;font-weight:700;margin:0}.footer-brand-subtitle{font-size:14px;color:#9ca3af;margin:0}.footer-description{color:#9ca3af;line-height:1.6}.footer-links-title,.footer-support-title{font-size:18px;font-weight:600;margin-bottom:16px}.footer-links-list,.footer-support-list{list-style:none}.footer-links-list li,.footer-support-list li{margin-bottom:8px}.footer-link{color:#9ca3af;text-decoration:none}.footer-bottom{border-top:1px solid #374151;padding-top:24px;text-align:center}.footer-copyright{color:#9ca3af}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:20px;z-index:1000}.modal-content{background:#fff;border-radius:16px;max-width:400px;width:100%;padding:22px;position:relative;max-height:80vh;overflow-y:auto}.register-modal{max-width:500px}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:#6b7280;padding:4px;border-radius:4px}.modal-close:hover{color:#1f2937}.modal-close svg{width:24px;height:24px}.modal-header{text-align:center;margin-bottom:32px}.modal-icon{width:64px;height:64px;background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:50%;margin:0 auto 16px;display:flex;align-items:center;justify-content:center}.modal-icon svg{width:32px;height:32px;color:#fff}.modal-title{font-size:24px;font-weight:700;color:#1f2937;margin-bottom:8px}.modal-subtitle{color:#6b7280}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1px;margin-bottom:10px}.form-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.input-wrapper{position:relative}.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:#9ca3af}.form-input{width:100%;padding:6px 8x;border:1px solid #d1d5db;border-radius:8px;font-size:16px;color:#1f2937;background:#fff;position:relative;z-index:2}.input-wrapper .form-input{padding-left:44px}.form-input:focus{outline:none;border-color:transparent;box-shadow:0 0 0 2px #3b82f6}.form-input::placeholder{color:#9ca3af}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:16px;display:flex;align-items:center;gap:12px;margin-bottom:20px}.error-icon{color:#f87171;flex-shrink:0}.error-text{color:#b91c1c;font-size:14px}.submit-button{width:100%;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-weight:600;padding:12px 16px;border:none;border-radius:8px;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px}.submit-button:hover:not(:disabled){background:linear-gradient(135deg,#1d4ed8,#6d28d9)}.submit-button:disabled{background:linear-gradient(135deg,#9ca3af,#9ca3af);cursor:not-allowed}.spinner{width:20px;height:20px;border:2px solid white;border-top:2px solid transparent;border-radius:50%;animation:spin 1s linear infinite}.modal-footer{text-align:center}.modal-footer-text{color:#6b7280;font-size:16px}.modal-link{color:#2563eb;font-weight:600;background:none;border:none;cursor:pointer;text-decoration:none}.modal-link:hover{color:#1d4ed8}@media (max-width: 1200px){.container,.header-container{padding:0 30px}}@media (max-width: 768px){.container,.header-container{padding:0 20px}.hero-section{padding:80px 0;min-height:auto}.hero-title{font-size:36px}.hero-buttons{flex-direction:column;gap:12px}.btn-hero-primary,.btn-hero-secondary{width:100%;justify-content:center}.section-title{font-size:28px}.about-grid,.footer-grid{grid-template-columns:1fr;gap:32px}.header-content{flex-direction:column;height:auto;padding:16px 0;gap:16px}.modal-content{margin:10px;padding:12x}.form-row{grid-template-columns:1fr;gap:0}.features-section,.about-section{padding:80px 0}}@media (max-width: 480px){.hero-title{font-size:28px}.hero-description{font-size:18px}.btn-hero-primary,.btn-hero-secondary{font-size:16px;padding:14px 24px}.header-buttons{flex-direction:column;gap:8px;width:100%}.btn-secondary,.btn-primary{width:100%;justify-content:center}}.layout{display:flex;flex-direction:column;min-height:100vh;background-color:#f5f7fa;width:100vw}.content{flex-grow:1;padding:2rem 1rem;width:100%;max-width:100%;margin:0 auto;box-sizing:border-box;background-color:#f5f7fa}.navbar{background-color:#021120;padding:1rem 2rem;color:#fff;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:1000}.nav-brand{color:#fff;text-decoration:none;font-size:clamp(1.2rem,2vw,1.8rem);font-weight:700;transition:opacity .3s ease;display:flex;align-items:center;gap:.5rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.modal-overlay{position:fixed;inset:0;background-color:#0009;z-index:999;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .2s ease}.notifications-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;z-index:1000;width:90%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;animation:modalSlideIn .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #eee;background-color:#f8f9fa;border-radius:12px 12px 0 0}.modal-header h4{margin:0;color:#333;font-size:1.25rem;font-weight:600}.close-modal{background:none;border:none;font-size:2rem;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;line-height:1}.close-modal:hover{color:#333;background-color:#0000000d}.modal-content{padding:0;overflow-y:auto;flex:1;max-height:calc(80vh - 80px)}.modal-content .notification-item{padding:1.25rem 1.5rem;border-bottom:1px solid #eee;background-color:#fff;transition:background-color .2s}.modal-content .notification-item:hover{background-color:#f8f9fa}.modal-content .notification-item:last-child{border-bottom:none;border-radius:0 0 12px 12px}.modal-content .no-notifications{padding:3rem 2rem;text-align:center;color:#666;font-style:italic;font-size:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes slideUpMobile{0%{transform:translateY(100%)}to{transform:translateY(0)}}.nav-brand:hover{opacity:.8}.brand-full{display:inline}.brand-abbreviated{display:none}@media (min-width: 1025px){.brand-full{display:none}.brand-abbreviated{display:inline}}.role-indicator{font-size:.9rem;background-color:#fff3;padding:.4rem 1rem;border-radius:20px;white-space:nowrap;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);transition:all .3s ease}.role-indicator:hover{background-color:#ffffff4d;transform:translateY(-1px)}.nav-left{display:flex;align-items:center;flex:1;min-width:0}.nav-right{display:flex;align-items:center;gap:1rem}.back-arrow{background:none;border:none;cursor:pointer;padding:.5rem;margin-right:.5rem;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background-color .2s}.back-arrow:hover{background-color:#ffffff1a}.back-arrow svg{width:20px;height:20px;color:#fff}.menu-container{position:relative}.hamburger-menu{background:none;border:none;cursor:pointer;padding:.5rem;display:flex;flex-direction:column;gap:3px;border-radius:4px;transition:background-color .2s}.hamburger-menu:hover{background-color:#ffffff1a}.hamburger-line{width:20px;height:2px;background-color:#fff;border-radius:1px;transition:all .3s ease}.dropdown-menu{position:absolute;top:100%;right:0;background-color:#fff;border-radius:4px;box-shadow:0 4px 12px #00000026;min-width:120px;z-index:1000;margin-top:.5rem;overflow:hidden}.menu-item{width:100%;padding:.75rem 1rem;border:none;background:none;text-align:left;cursor:pointer;font-size:.875rem;transition:background-color .2s}.menu-item:hover{background-color:#f8f9fa}.menu-item.sign-out{color:#e74c3c;font-weight:500}.menu-item.sign-out:hover{background-color:#fef2f2}.notification-container{position:relative;margin-right:10px}.notification-bell{background:transparent;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:50%;position:relative;transition:background-color .2s;display:flex;align-items:center;justify-content:center}.notification-bell:hover{background-color:#ffffff1a}.notification-badge{position:absolute;top:2px;right:2px;background-color:#e74c3c;color:#fff;border-radius:50%;width:16px;height:16px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700;border:2px solid white;box-sizing:border-box}.notifications-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;width:350px;max-height:400px;overflow:hidden;z-index:1001;margin-top:.5rem}.notifications-header{padding:15px;border-bottom:1px solid #eee;background-color:#f8f9fa;border-radius:8px 8px 0 0}.notifications-header h4{margin:0;color:#333;font-size:16px;font-weight:600}.notifications-content{max-height:300px;overflow-y:auto}.no-notifications{padding:20px;text-align:center;color:#666;font-style:italic}.notification-item{padding:15px;border-bottom:1px solid #eee;background-color:#fff;transition:background-color .2s}.notification-item:hover{background-color:#f8f9fa}.notification-item:last-child{border-bottom:none;border-radius:0 0 8px 8px}.notification-info{margin-bottom:10px}.notification-info strong{color:#333;font-size:14px;display:block;margin-bottom:4px}.notification-details{color:#666;font-size:12px;line-height:1.4}.notification-actions{display:flex;gap:8px;margin-top:8px}.approve-btn,.reject-btn{padding:6px 12px;border:none;border-radius:4px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s;flex:1;text-align:center}.approve-btn{background-color:#2ecc71;color:#fff}.approve-btn:hover{background-color:#27ae60;transform:translateY(-1px)}.reject-btn{background-color:#e74c3c;color:#fff}.reject-btn:hover{background-color:#c0392b;transform:translateY(-1px)}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;font-size:18px;color:#666}.footer{background-color:#021120;color:#ffffffb3;padding:2rem;text-align:center;border-top:1px solid rgba(255,255,255,.1)}.footer p{margin:.5rem 0;font-size:.9rem}.footer-links{display:flex;justify-content:center;gap:2rem;margin-top:1rem}.footer-link{color:#ffffffb3;text-decoration:none;font-size:.9rem;transition:color .3s ease}.footer-link:hover{color:#fff}@media (max-width: 1024px){.navbar{padding:1rem 1.5rem}.content{padding:1.5rem}.notifications-dropdown{width:320px;right:-10px}}@media (max-width: 768px){.navbar{padding:.75rem 1rem;flex-wrap:wrap}.nav-brand{font-size:1rem;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav-right{gap:.5rem}.role-indicator{font-size:.75rem;padding:.2rem .4rem}.content{padding:1rem .75rem}.dropdown-menu{right:-.5rem;min-width:100px}.menu-item{padding:.6rem .75rem;font-size:.8rem}.back-arrow{margin-right:.25rem;padding:.25rem}.back-arrow svg{width:18px;height:18px}.notification-bell{padding:6px}.notification-badge{width:14px;height:14px;font-size:9px;top:1px;right:1px}.notifications-dropdown{width:300px;right:-20px;max-height:350px}.notification-item{padding:12px}.notification-actions{flex-direction:column;gap:6px}.approve-btn,.reject-btn{flex:none;padding:8px 12px}.notifications-modal{width:95%;max-width:none;max-height:90vh}.modal-header{padding:1.25rem}.modal-header h4{font-size:1.1rem}.modal-content .notification-item{padding:1rem}}@media (max-width: 480px){.navbar{padding:.5rem .75rem}.nav-brand{font-size:.9rem;max-width:calc(100vw - 120px)}.role-indicator{display:none}.content{padding:.75rem .5rem}.hamburger-menu{padding:.25rem}.hamburger-line{width:18px}.dropdown-menu{right:-.25rem;min-width:90px}.notifications-dropdown{width:280px;right:-30px;max-height:300px}.notifications-header{padding:12px}.notifications-header h4{font-size:14px}.notification-item{padding:10px}.notification-info strong{font-size:13px}.notification-details{font-size:11px}.approve-btn,.reject-btn{font-size:11px;padding:6px 10px}.notifications-modal{width:100%;height:100%;max-height:100vh;border-radius:0;top:0;left:0;transform:none;animation:slideUpMobile .3s ease}.modal-header{border-radius:0;padding:1rem}.modal-content .notification-item:last-child{border-radius:0}}@media (min-width: 1025px){.navbar{padding:1rem 2rem}.content{padding:2rem;width:100%}.notifications-dropdown{width:380px}}.dashboard-card{background-color:#fff;padding:25px;border-radius:8px;box-shadow:0 2px 4px #0000001a;text-decoration:none;color:#2c3e50;transition:all .3s ease;display:block}.dashboard-card:hover{transform:translateY(-3px);box-shadow:0 6px 12px #00000026}.dashboard-card h3{margin-bottom:10px;font-size:1.3rem;color:#2c3e50}.dashboard-card p{color:#7f8c8d;font-size:.95rem;line-height:1.4}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:30px}:root{--primary-blue: #2563eb;--primary-blue-hover: #1d4ed8;--primary-blue-light: #eff6ff;--primary-blue-lighter: #f0f9ff;--secondary-blue: #3b82f6;--accent-blue: #60a5fa;--dark-blue: #1e40af;--success-color: #22c55e;--warning-color: #facc15;--danger-color: #ef4444;--danger-light: #fee2e2;--info-color: #06b6d4;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--white: #ffffff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--border-color: #e2e8f0;--background: #ffffff;--card-background: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--shadow-blue: 0 4px 14px 0 rgba(37, 99, 235, .15);--transition: all .3s cubic-bezier(.4, 0, .2, 1)}.course-form-container{width:100%;max-width:700px;margin:0 auto;background:var(--white);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden;animation:slideUp .3s ease-out}.course-form{display:flex;flex-direction:column;height:100%}.form-header{display:flex;justify-content:space-between;align-items:center;padding:24px 32px;background:linear-gradient(135deg,var(--primary-blue),var(--accent-blue));color:var(--white);position:relative;overflow:hidden}.form-header:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.1),transparent);animation:shimmer 2s infinite}@keyframes shimmer{to{left:100%}}.form-header h2{margin:0;font-size:24px;font-weight:600;letter-spacing:-.02em}.close-btn{width:36px;height:36px;border-radius:50%;background:#fff3;border:none;color:var(--white);font-size:20px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.form-body{padding:32px;overflow-y:auto;max-height:60vh;background:var(--white)}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px 16px;border:2px solid var(--gray-200);border-radius:10px;font-size:14px;transition:var(--transition);background:var(--white);color:var(--text-primary)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-blue);background:var(--primary-blue-lighter);box-shadow:0 0 0 4px #2563eb1a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.form-group input[type=number]::-webkit-outer-spin-button,.form-group input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.form-group textarea{resize:vertical;min-height:100px;font-family:inherit}.form-group select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;appearance:none}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--danger-color);background:var(--danger-light)}.form-group input.error:focus,.form-group select.error:focus,.form-group textarea.error:focus{border-color:var(--danger-color);box-shadow:0 0 0 4px #ef44441a}.error-text{display:block;margin-top:6px;font-size:13px;color:var(--danger-color);font-weight:500;animation:slideDown .2s ease-out}.checkbox-label{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:14px;color:var(--text-primary);position:relative;padding-left:32px}.checkbox-label input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:50%;left:0;transform:translateY(-50%);height:20px;width:20px;background-color:var(--white);border:2px solid var(--gray-300);border-radius:6px;transition:var(--transition)}.checkbox-label:hover .checkmark{border-color:var(--primary-blue);background-color:var(--primary-blue-lighter)}.checkbox-label input:checked~.checkmark{background-color:var(--primary-blue);border-color:var(--primary-blue)}.checkmark:after{content:"";position:absolute;display:none;left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.checkbox-label input:checked~.checkmark:after{display:block}.form-footer{display:flex;justify-content:flex-end;gap:12px;padding:24px 32px;background:var(--gray-50);border-top:1px solid var(--gray-200)}.btn-primary,.btn-secondary{padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;justify-content:center;gap:8px;min-width:120px}.btn-primary{background:var(--primary-blue);color:var(--white);border:none;box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--white);color:var(--primary-blue);border:2px solid var(--primary-blue)}.btn-secondary:hover:not(:disabled){background:var(--primary-blue-lighter);border-color:var(--primary-blue-hover)}.btn-primary:disabled,.btn-secondary:disabled{opacity:.5;cursor:not-allowed;transform:none}.spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid var(--white);border-radius:50%;animation:spin .8s linear infinite}.course-form input:disabled,.course-form select:disabled,.course-form textarea:disabled{background:var(--gray-100);color:var(--text-muted);cursor:not-allowed;opacity:.7}.course-form *:focus-visible{outline:2px solid var(--primary-blue);outline-offset:2px}.form-body::-webkit-scrollbar{width:8px}.form-body::-webkit-scrollbar-track{background:var(--gray-100);border-radius:4px}.form-body::-webkit-scrollbar-thumb{background:var(--gray-400);border-radius:4px}.form-body::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}@media (max-width: 768px){.course-form-container{border-radius:0;max-width:100%;height:100vh}.form-header{padding:20px 24px}.form-header h2{font-size:20px}.form-body{padding:24px;max-height:calc(100vh - 200px)}.form-row{grid-template-columns:1fr;gap:0}.form-footer{padding:20px 24px;flex-direction:column-reverse}.btn-primary,.btn-secondary{width:100%}}@media (max-width: 480px){.form-header{padding:16px 20px}.form-body{padding:20px}.form-group{margin-bottom:20px}.close-btn{width:32px;height:32px;font-size:18px}}.demo-container{min-height:100vh;background:linear-gradient(135deg,var(--gray-50),var(--primary-blue-lighter));display:flex;align-items:center;justify-content:center;padding:20px}body{background:var(--white);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;margin:0;padding:0}.teacher-courses-page{max-width:1400px;margin:0 auto;padding:32px;background:var(--white);min-height:100vh;animation:fadeIn .5s ease-in}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid var(--gray-100)}.page-header h1{font-size:36px;font-weight:700;color:var(--text-primary);margin:0;letter-spacing:-.02em}.btn-primary{padding:12px 24px;background:var(--primary-blue);color:#fff;border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);display:inline-flex;align-items:center;gap:8px;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background:var(--primary-blue-hover);transform:translateY(-2px);box-shadow:var(--shadow-blue)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.error-banner{background:#fef2f2;border:1px solid #fecaca;border-radius:12px;padding:16px 20px;margin-bottom:24px;display:flex;align-items:center;gap:12px;animation:slideDown .3s ease-out}.error-icon{font-size:20px}.error-banner span:not(.error-icon){flex:1;color:var(--danger-color);font-weight:500}.retry-btn{padding:6px 16px;background:var(--white);color:var(--danger-color);border:1px solid var(--danger-color);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition)}.retry-btn:hover{background:var(--danger-color);color:#fff}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-container p{color:var(--text-secondary);font-size:16px;margin:0}.form-modal{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}.modal-content{background:var(--white);border-radius:16px;padding:32px;max-width:600px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s ease-out}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:24px;margin-top:32px}.course-card{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;padding:24px;transition:var(--transition);cursor:pointer;position:relative;overflow:hidden;box-shadow:var(--shadow-sm)}.course-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-blue),var(--accent-blue));transform:scaleX(0);transition:transform .3s}.course-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-blue);border-color:var(--accent-blue)}.course-card:hover:before{transform:scaleX(1)}.course-card.clickable{cursor:pointer}.course-card .course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.course-card h3{margin:0;font-size:20px;font-weight:600;color:var(--text-primary);line-height:1.3}.status{padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.status.active{background:var(--primary-blue-lighter);color:var(--dark-blue);border:1px solid var(--accent-blue)}.status.inactive{background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--gray-300)}.course-code{font-size:14px;font-weight:600;color:var(--primary-blue);margin:0 0 12px;display:inline-block;padding:4px 10px;background:var(--primary-blue-lighter);border-radius:6px}.course-description{color:var(--text-secondary);font-size:15px;line-height:1.6;margin:0 0 16px;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.course-meta{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px;padding:12px;background:var(--gray-50);border-radius:8px}.course-meta span{font-size:13px;color:var(--text-secondary);display:flex;align-items:center;gap:4px;padding:4px 8px;background:var(--white);border-radius:6px;border:1px solid var(--gray-200)}.course-dates{display:flex;justify-content:space-between;gap:12px;padding-top:16px;border-top:1px solid var(--gray-200);font-size:13px;color:var(--text-muted)}.course-dates span{display:flex;align-items:center;gap:4px}.empty-state{text-align:center;padding:80px 40px;background:var(--white);border:2px dashed var(--gray-300);border-radius:16px;margin-top:32px}.empty-icon{font-size:64px;margin-bottom:24px;opacity:.8}.empty-state h3{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 12px}.empty-state p{font-size:16px;color:var(--text-secondary);max-width:400px;margin:0 auto 24px}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.teacher-courses-page{padding:24px}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}}@media (max-width: 768px){.teacher-courses-page{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.page-header h1{font-size:28px}.btn-primary{width:100%;justify-content:center}.courses-grid{grid-template-columns:1fr;gap:16px}.modal-content{width:95%;padding:24px;margin:16px}}@media (max-width: 480px){.teacher-courses-page{padding:12px}.page-header h1{font-size:24px}.course-card{padding:20px}.course-meta{flex-direction:column;gap:8px}.course-meta span{width:100%}.course-dates{flex-direction:column;gap:8px}.empty-state{padding:60px 20px}.empty-icon{font-size:48px}}.course-form{display:flex;flex-direction:column;gap:20px}.form-group label{font-size:14px;font-weight:600;color:var(--text-primary)}.form-group input,.form-group textarea,.form-group select{padding:10px 14px;border:1px solid var(--gray-300);border-radius:8px;font-size:14px;transition:var(--transition);background:var(--white)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2563eb1a}.form-group textarea{min-height:100px;resize:vertical}.form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:24px;padding-top:24px;border-top:1px solid var(--gray-200)}.btn-secondary{padding:10px 20px;background:var(--white);color:var(--primary-blue);border:1px solid var(--primary-blue);border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition)}.btn-secondary:hover{background:var(--primary-blue-lighter)}@media (max-width: 480px){.form-row{grid-template-columns:1fr}.form-actions{flex-direction:column}.btn-secondary{width:100%}}.modal-content{background-color:#fff;padding:25px;border-radius:8px;width:100%;max-width:500px;box-shadow:0 4px 12px #00000026}.modal-content h3{margin-top:0;color:#333}.modal-content input[type=email]{width:100%;padding:10px;margin:10px 0;border:1px solid #ddd;border-radius:4px;font-size:16px}.course-footer{margin-top:auto;padding-top:15px;border-top:1px solid #eee;display:flex;justify-content:flex-end}.enroll-btn{background:#4caf50;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background .3s}.enroll-btn:hover{background:#45a049}.enroll-btn:disabled{background:#ccc;cursor:not-allowed}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}.btn-secondary{background:#f5f5f5;color:#333;border:1px solid #ddd;padding:8px 16px;border-radius:4px;cursor:pointer}.btn-secondary:hover{background:#e9e9e9}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.error-text{color:#d32f2f;margin:10px 0;font-size:.9rem}.students-list{max-height:400px;overflow-y:auto;border:1px solid #e0e0e0;border-radius:6px;padding:1rem;margin-bottom:1.5rem}.student-item{padding:.75rem 0;border-bottom:1px solid #f0f0f0}.student-info{display:flex;align-items:center;gap:.75rem}.student-number{font-weight:700;color:#666;min-width:25px}.student-name{font-weight:600;color:#333;flex:1}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.confirmation-modal{z-index:1100;background-color:#000000b3}.modal-content{background:#fff;padding:2rem;border-radius:8px;max-width:500px;width:90%;max-height:70vh;overflow-y:auto;box-shadow:0 4px 20px #00000026}.modal-content h3{margin-top:0;margin-bottom:1.5rem;color:#333;font-size:1.5rem}.student-modal{max-width:600px;width:95%}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #e0e0e0}.modal-header h3{margin:0}.modal-close-btn{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.modal-close-btn:hover{background-color:#f0f0f0;color:#333}.search-bar{margin-bottom:1rem}.search-input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem;box-sizing:border-box;transition:border-color .2s}.search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.student-count{margin-bottom:1rem;color:#666;font-size:.9rem}.students-list{max-height:none;border:1px solid #e0e0e0;border-radius:6px;margin-bottom:1rem}.student-item{padding:1rem;border-bottom:1px solid #f0f0f0;transition:background-color .2s}.student-info{display:flex;align-items:flex-start;gap:.75rem}.student-number{font-weight:700;color:#666;min-width:30px;margin-top:2px}.student-details{flex:1;display:flex;flex-direction:column;gap:.25rem}.student-name{font-weight:600;color:#333;font-size:1rem}.student-email{color:#666;font-size:.9rem}.remove-student-btn{background-color:#dc3545;color:#fff;border:none;border-radius:50%;width:28px;height:28px;cursor:pointer;font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.remove-student-btn:hover:not(:disabled){background-color:#c82333;transform:scale(1.1)}.remove-student-btn:disabled{background-color:#ccc;cursor:not-allowed;transform:none}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:1rem 0;border-top:1px solid #e0e0e0}.pagination-btn{background-color:#007bff;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.pagination-btn:hover:not(:disabled){background-color:#0056b3}.pagination-btn:disabled{background-color:#ccc;cursor:not-allowed}.pagination-info{font-weight:500;color:#333}.no-results{text-align:center;padding:2rem;color:#666;font-style:italic}.no-results p{margin:0}.remove-student-btn:disabled{background-color:#6c757d}@media (max-width: 768px){.student-modal{width:98%;max-height:85vh}.modal-header{flex-direction:column;align-items:flex-start;gap:1rem}.modal-close-btn{position:absolute;top:1rem;right:1rem}.student-info{flex-direction:column;gap:.5rem}.remove-student-btn{align-self:flex-end;margin-top:.5rem}.pagination{flex-direction:column;gap:1rem}.pagination-info{order:-1}}.no-students{text-align:center;color:#666;font-style:italic;padding:2rem}.modal-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.modal-actions button{padding:.5rem 1rem;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:all .2s}.btn-primary{background-color:#007bff;color:#fff}.btn-primary:hover:not(:disabled){background-color:#0056b3}.btn-primary:disabled{background-color:#ccc;cursor:not-allowed}.btn-secondary{background-color:#6c757d;color:#fff}.btn-secondary:hover:not(:disabled){background-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:disabled{background-color:#ccc;cursor:not-allowed}.confirmation-modal .modal-content{max-width:450px;text-align:center}.confirmation-icon{font-size:3rem;margin-bottom:1rem}.confirmation-modal h3{color:#dc3545;margin-bottom:1rem}.confirmation-modal p{margin-bottom:1rem;line-height:1.5}.warning-text{color:#856404;background-color:#fff3cd;border:1px solid #ffeeba;padding:.75rem;border-radius:4px;font-size:.9rem}.confirmation-modal .modal-actions{justify-content:center;gap:1rem;margin-top:1.5rem}.confirmation-modal .modal-actions button{min-width:120px}.course-footer{display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #eee}.view-students-btn{flex:1;padding:.5rem;background-color:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.view-students-btn:hover{background-color:#218838}.enroll-btn{flex:1;padding:.5rem;background-color:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.85rem;transition:all .2s}.enroll-btn:hover{background-color:#0056b3}input[type=email]{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;margin:1rem 0;box-sizing:border-box}input[type=email]:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.error-text{color:#dc3545;font-size:.9rem;margin:.5rem 0}@media (max-width: 768px){.course-footer{flex-direction:column}.modal-content{width:95%;padding:1.5rem;max-height:80vh}.student-info{flex-wrap:wrap;gap:.5rem}.student-email{width:100%;margin-left:1.75rem}}.assignment-creator{min-height:100vh;background:#f8fafc;width:100%;overflow-x:hidden}.header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;position:sticky;top:0;z-index:10}.header-content{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem;max-width:1400px;margin:0 auto}.header-left{display:flex;align-items:center;gap:1rem}.header-left>div{display:flex;flex-direction:column;gap:.5rem}.title{font-size:1.75rem;font-weight:700;color:#1f2937;margin:0}.badges{display:flex;gap:.5rem;align-items:center}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:500}.badge-published{background:#dcfce7;color:#166534}.badge-unpublished{background:#fef3c7;color:#92400e}.badge-locked{background:#ddd6fe;color:#5b21b6}.badge-editing{background:#dbeafe;color:#1d4ed8}.points-display{background:#f3f4f6;color:#374151;padding:.25rem .5rem;border-radius:.375rem;font-size:.75rem;font-weight:500}.header-actions{display:flex;gap:.5rem;align-items:center}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background:#2563eb}.btn-secondary{background:#f3f4f6;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-success{background:#10b981;color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-large{padding:.75rem 1.5rem;font-size:1rem}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:2rem;height:2rem;border-radius:.375rem;border:none;background:#f3f4f6;color:#6b7280;cursor:pointer;transition:all .2s}.icon-btn:hover{background:#e5e7eb;color:#374151}.icon-btn.danger{background:#fecaca;color:#dc2626}.icon-btn.danger:hover{background:#fca5a5}.main-content{max-width:1400px;margin:0 auto;padding:2rem}.tabs{margin-bottom:2rem}.tab-nav{display:flex;border-bottom:1px solid #e5e7eb}.tab{padding:.75rem 1.5rem;border:none;background:none;color:#6b7280;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s}.card{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb}.card-header{font-size:1.25rem;font-weight:600;color:#1f2937;margin-bottom:1rem}.form-group{margin-bottom:1.5rem}.form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.form-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;resize:vertical;font-family:inherit;transition:border-color .2s}.form-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-select{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;background:#fff;cursor:pointer;transition:border-color .2s}.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.checkbox{width:1rem;height:1rem;accent-color:#3b82f6}.checkbox-group{display:flex;flex-direction:column;gap:.75rem}.grid{display:grid;gap:2rem}.grid-3{grid-template-columns:1fr}@media (min-width: 1024px){.grid-3{grid-template-columns:2fr 1fr}}.questions-header{display:flex;justify-content:space-between;align-items:center}.questions-info{font-size:.875rem;color:#6b7280;margin:0}.empty-state{text-align:center;padding:3rem 1rem}.empty-icon{display:flex;justify-content:center;margin-bottom:1rem;color:#9ca3af}.empty-title{font-size:1.125rem;font-weight:600;color:#374151;margin:0 0 .5rem}.empty-description{color:#6b7280;margin:0 0 1.5rem}.question-editor{border:2px solid #3b82f6}.question-editor-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem}.question-title-input{flex:1;font-size:1.125rem;font-weight:600;border:1px solid #d1d5db;border-radius:.375rem;padding:.5rem}.question-controls{display:flex;align-items:center;gap:.5rem}.points-input{width:4rem;padding:.5rem;border:1px solid #d1d5db;border-radius:.375rem;text-align:center}.image-preview-container{position:relative;display:inline-block}.question-image-preview{max-width:200px;max-height:200px;border-radius:.375rem;border:1px solid #d1d5db}.remove-image-btn{position:absolute;top:.5rem;right:.5rem;background:#000000b3;color:#fff;border:none;border-radius:50%;width:1.5rem;height:1.5rem;display:flex;align-items:center;justify-content:center;cursor:pointer}.image-upload-area{border:2px dashed #d1d5db;border-radius:.5rem;padding:2rem;text-align:center;transition:border-color .2s}.image-upload-area:hover{border-color:#3b82f6}.image-upload-label{display:flex;flex-direction:column;align-items:center;gap:.5rem;cursor:pointer;color:#6b7280}.image-upload-hint{font-size:.75rem;color:#9ca3af}.answer-options{margin-top:1rem}.answer-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:.75rem}.correct-btn{width:1.5rem;height:1.5rem;border:2px solid #d1d5db;border-radius:50%;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-top:.75rem;transition:all .2s}.correct-btn:hover{border-color:#10b981}.correct-btn.correct{border-color:#10b981;background:#10b981}.correct-indicator{width:.5rem;height:.5rem;background:#fff;border-radius:50%}.answer-inputs{flex:1;display:flex;flex-direction:column;gap:.5rem}.answer-input,.feedback-input{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem}.add-answer{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:2px dashed #d1d5db;background:none;border-radius:.375rem;color:#6b7280;cursor:pointer;transition:all .2s}.add-answer:hover{border-color:#3b82f6;color:#3b82f6}.question-list{display:flex;flex-direction:column;gap:1rem}.question-item{transition:all .2s}.question-item:hover{box-shadow:0 4px 6px -1px #0000001a}.question-header{display:flex;justify-content:space-between;align-items:flex-start}.question-content{flex:1}.question-title{font-size:1.125rem;font-weight:600;color:#1f2937;margin:0 0 .25rem}.question-meta{font-size:.875rem;color:#6b7280;margin:0 0 .5rem}.question-text{color:#374151;margin:0 0 .5rem;line-height:1.5}.question-thumbnail{max-width:100px;max-height:100px;border-radius:.375rem;border:1px solid #d1d5db}.question-actions{display:flex;gap:.5rem}.info-box{background:#f0f9ff;border:1px solid #0ea5e9;border-radius:.375rem;padding:1rem}.info-text{color:#0369a1;margin:0;font-size:.875rem}.bottom-actions{margin-top:3rem;padding:1.5rem;background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.notify-checkbox{display:flex;align-items:center;gap:.5rem;cursor:pointer}.notify-text{font-size:.875rem;color:#374151}.bottom-buttons{display:flex;gap:.75rem}.error-banner{max-width:1400px;margin:0 auto;padding:0 2rem}.loading{display:flex;align-items:center;justify-content:center;min-height:50vh;font-size:1.125rem;color:#6b7280}.error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;text-align:center}.error p{font-size:1.125rem;color:#dc2626;margin-bottom:1rem}@media (max-width: 768px){.header-content{flex-direction:column;gap:1rem;padding:1rem}.header-left{flex-direction:column;align-items:flex-start;gap:.5rem;width:100%}.header-actions{width:100%;justify-content:flex-end}.main-content{padding:1rem}.question-editor-header{flex-direction:column;align-items:stretch}.question-controls{justify-content:space-between}.answer-item{flex-direction:column;gap:.5rem}.correct-btn{align-self:flex-start;margin-top:0}.bottom-actions{flex-direction:column;gap:1rem;align-items:stretch}.bottom-buttons{justify-content:stretch}.btn-large{flex:1}}@media (max-width: 480px){.title{font-size:1.5rem}.badges{flex-wrap:wrap}.badge{font-size:.7rem}.tab{padding:.5rem 1rem;font-size:.875rem}.card{padding:1rem}.question-header{flex-direction:column;gap:1rem}.question-actions{align-self:flex-end}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.btn:focus,.icon-btn:focus,.tab:focus{outline:2px solid #3b82f6;outline-offset:2px}.form-input:focus,.form-textarea:focus,.form-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}@keyframes spin{to{transform:rotate(360deg)}}.spinner{animation:spin 1s linear infinite}.question-list::-webkit-scrollbar{width:8px}.question-list::-webkit-scrollbar-track{background:#f1f5f9}.question-list::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.question-list::-webkit-scrollbar-thumb:hover{background:#94a3b8}.latex-preview{font-size:1.1em;min-height:24px;overflow-x:auto;padding:8px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef;margin-top:8px}.katex{font-size:1.1em!important}@font-face{font-family:KaTeX_AMS;font-style:normal;font-weight:400;src:url(/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2) format("woff2"),url(/assets/KaTeX_AMS-Regular-DMm9YOAa.woff) format("woff"),url(/assets/KaTeX_AMS-Regular-DRggAlZN.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf) format("truetype")}@font-face{font-family:KaTeX_Caligraphic;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2) format("woff2"),url(/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff) format("woff"),url(/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff) format("woff"),url(/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf) format("truetype")}@font-face{font-family:KaTeX_Fraktur;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2) format("woff2"),url(/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff) format("woff"),url(/assets/KaTeX_Fraktur-Regular-CB_wures.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:700;src:url(/assets/KaTeX_Main-Bold-Cx986IdX.woff2) format("woff2"),url(/assets/KaTeX_Main-Bold-Jm3AIy58.woff) format("woff"),url(/assets/KaTeX_Main-Bold-waoOVXN0.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2) format("woff2"),url(/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff) format("woff"),url(/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2) format("woff2"),url(/assets/KaTeX_Main-Italic-BMLOBm91.woff) format("woff"),url(/assets/KaTeX_Main-Italic-3WenGoN9.ttf) format("truetype")}@font-face{font-family:KaTeX_Main;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Main-Regular-B22Nviop.woff2) format("woff2"),url(/assets/KaTeX_Main-Regular-Dr94JaBh.woff) format("woff"),url(/assets/KaTeX_Main-Regular-ypZvNtVU.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:700;src:url(/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2) format("woff2"),url(/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff) format("woff"),url(/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf) format("truetype")}@font-face{font-family:KaTeX_Math;font-style:italic;font-weight:400;src:url(/assets/KaTeX_Math-Italic-t53AETM-.woff2) format("woff2"),url(/assets/KaTeX_Math-Italic-DA0__PXp.woff) format("woff"),url(/assets/KaTeX_Math-Italic-flOr_0UB.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:700;src:url(/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff) format("woff"),url(/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:italic;font-weight:400;src:url(/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff) format("woff"),url(/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf) format("truetype")}@font-face{font-family:KaTeX_SansSerif;font-style:normal;font-weight:400;src:url(/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2) format("woff2"),url(/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff) format("woff"),url(/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf) format("truetype")}@font-face{font-family:KaTeX_Script;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Script-Regular-D3wIWfF6.woff2) format("woff2"),url(/assets/KaTeX_Script-Regular-D5yQViql.woff) format("woff"),url(/assets/KaTeX_Script-Regular-C5JkGWo-.ttf) format("truetype")}@font-face{font-family:KaTeX_Size1;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2) format("woff2"),url(/assets/KaTeX_Size1-Regular-C195tn64.woff) format("woff"),url(/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf) format("truetype")}@font-face{font-family:KaTeX_Size2;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2) format("woff2"),url(/assets/KaTeX_Size2-Regular-oD1tc_U0.woff) format("woff"),url(/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf) format("truetype")}@font-face{font-family:KaTeX_Size3;font-style:normal;font-weight:400;src:url(data:font/woff2;base64,d09GMgABAAAAAA4oAA4AAAAAHbQAAA3TAAEAAAAAAAAAAAAAAAAAAAAAAAAAAAAABmAAgRQIDgmcDBEICo1oijYBNgIkA14LMgAEIAWJAAeBHAyBHBvbGiMRdnO0IkRRkiYDgr9KsJ1NUAf2kILNxgUmgqIgq1P89vcbIcmsQbRps3vCcXdYOKSWEPEKgZgQkprQQsxIXUgq0DqpGKmIvrgkeVGtEQD9DzAO29fM9jYhxZEsL2FeURH2JN4MIcTdO049NCVdxQ/w9NrSYFEBKTDKpLKfNkCGDc1RwjZLQcm3vqJ2UW9Xfa3tgAHz6ivp6vgC2yD4/6352ndnN0X0TL7seypkjZlMsjmZnf0Mm5Q+JykRWQBKCVCVPbARPXWyQtb5VgLB6Biq7/Uixcj2WGqdI8tGSgkuRG+t910GKP2D7AQH0DB9FMDW/obJZ8giFI3Wg8Cvevz0M+5m0rTh7XDBlvo9Y4vm13EXmfttwI4mBo1EG15fxJhUiCLbiiyCf/ZA6MFAhg3pGIZGdGIVjtPn6UcMk9A/UUr9PhoNsCENw1APAq0gpH73e+M+0ueyHbabc3vkbcdtzcf/fiy+NxQEjf9ud/ELBHAXJ0nk4z+MXH2Ev/kWyV4k7SkvpPc9Qr38F6RPWnM9cN6DJ0AdD1BhtgABtmoRoFCvPsBAumNm6soZG2Gk5GyVTo2sJncSyp0jQTYoR6WDvTwaaEcHsxHfvuWhHA3a6bN7twRKtcGok6NsCi7jYRrM2jExsUFMxMQYuJbMhuWNOumEJy9hi29Dmg5zMp/A5+hhPG19j1vBrq8JTLr8ki5VLPmG/PynJHVul440bxg5xuymHUFPBshC+nA9I1FmwbRBTNHAcik3Oae0cxKoI3MOriM42UrPe51nsaGxJ+WfXubAsP84aabUlQSJ1IiE0iPETLUU4CATgfXSCSpuRFRmCGbO+wSpAnzaeaCYW1VNEysRtuXCEL1kUFUbbtMv3Tilt/1c11jt3Q5bbMa84cpWipp8Elw3MZhOHsOlwwVUQM3lAR35JiFQbaYCRnMF2lxAWoOg2gyoIV4PouX8HytNIfLhqpJtXB4vjiViUI8IJ7bkC4ikkQvKksnOTKICwnqWSZ9YS5f0WCxmpgjbIq7EJcM4aI2nmhLNY2JIUgOjXZFWBHb+x5oh6cwb0Tv1ackHdKi0I9OO2wE9aogIOn540CCCziyhN+IaejtgAONKznHlHyutPrHGwCx9S6B8kfS4Mfi4Eyv7OU730bT1SCBjt834cXsf43zVjPUqqJjgrjeGnBxSG4aYAKFuVbeCfkDIjAqMb6yLNIbCuvXhMH2/+k2vkNpkORhR59N1CkzoOENvneIosjYmuTxlhUzaGEJQ/iWqx4dmwpmKjrwTiTGTCVozNAYqk/zXOndWxuWSmJkQpJw3pK5KX6QrLt5LATMqpmPAQhkhK6PUjzHUn7E0gHE0kPE0iKkolgkUx9SZmVAdDgpffdyJKg3k7VmzYGCwVXGz/tXmkOIp+vcWs+EMuhhvN0h9uhfzWJziBQmCREGSIFmQIkgVpAnSBRmC//6hkLZwaVhwxlrJSOdqlFtOYxlau9F2QN5Y98xmIAsiM1HVp2VFX+DHHGg6Ecjh3vmqtidX3qHI2qycTk/iwxSt5UzTmEP92ZBnEWTk4Mx8Mpl78ZDokxg/KWb+Q0QkvdKVmq3TMW+RXEgrsziSAfNXFMhDc60N5N9jQzjfO0kBKpUZl0ZmwJ41j/B9Hz6wmRaJB84niNmQrzp9eSlQCDDzazGDdVi3P36VZQ+Jy4f9UBNp+3zTjqI4abaFAm+GShVaXlsGdF3FYzZcDI6cori4kMxUECl9IjJZpzkvitAoxKue+90pDMvcKRxLl53TmOKCmV/xRolNKSqqUxc6LStOETmFOiLZZptlZepcKiAzteG8PEdpnQpbOMNcMsR4RR2Bs0cKFEvSmIjAFcnarqwUL4lDhHmnVkwu1IwshbiCcgvOheZuYyOteufZZwlcTlLgnZ3o/WcYdzZHW/WGaqaVfmTZ1aWCceJjkbZqsfbkOtcFlUZM/jy+hXHDbaUobWqqXaeWobbLO99yG5N3U4wxco0rQGGcOLASFMXeJoham8M+/x6O2WywK2l4HGbq1CoUyC/IZikQhdq3SiuNrvAEj0AVu9x2x3lp/xWzahaxidezFVtdcb5uEnzyl0ZmYiuKI0exvCd4Xc9CV1KB0db00z92wDPde0kukbvZIWN6jUWFTmPIC/Y4UPCm8UfDTFZpZNon1qLFTkBhxzB+FjQRA2Q/YRJT8pQigslMaUpFyAG8TMlXigiqmAZX4xgijKjRlGpLE0GdplRfCaJo0JQaSxNBk6ZmMzcya0FmrcisDdn0Q3HI2sWSppYigmlM1XT/kLQZSNpMJG0WkjYbSZuDpM1F0uYhFc1HxU4m1QJjDK6iL0S5uSj5rgXc3RejEigtcRBtqYPQsiTskmO5vosV+q4VGIKbOkDg0jtRrq+Em1YloaTFar3EGr1EUC8R0kus1Uus00usL97ABr2BjXoDm/QGNhuWtMVBKOwg/i78lT7hBsAvDmwHc/ao3vmUbBmhjeYySZNWvGkfZAgISDSaDo1SVpzGDsAEkF8B+gEapViUoZgUWXcRIGFZNm6gWbAKk0bp0k1MHG9fLYtV4iS2SmLEQFARzRcnf9PUS0LVn05/J9MiRRBU3v2IrvW974v4N00L7ZMk0wXP1409CHo/an8zTRHD3eSJ6m8D4YMkZNl3M79sqeuAsr/m3f+8/yl7A50aiAEJgeBeMWzu7ui9UfUBCe2TIqZIoOd/3/udRBOQidQZUERzb2/VwZN1H/Sju82ew2H2Wfr6qvfVf3hqwDvAIpkQVFy4B9Pe9e4/XvPeceu7h3dvO56iJPf0+A6cqA2ip18ER+iFgggiuOkvj24bby0N9j2UHIkgqIt+sVgfodC4YghLSMjSZbH0VR/6dMDrYJeKHilKTemt6v6kvzvn3/RrdWtr0GoN/xL+Sex/cPYLUpepx9cz/D46UPU5KXgAQa+NDps1v6J3xP1i2HtaDB0M9aX2deA7SYff//+gUCovMmIK/qfsFcOk+4Y5ZN97XlG6zebqtMbKgeRFi51vnxTQYBUik2rS/Cn6PC8ADR8FGxsRPB82dzfND90gIcshOcYUkfjherBz53odpm6TP8txlwOZ71xmfHHOvq053qFF/MRlS3jP0ELudrf2OeN8DHvp6ZceLe8qKYvWz/7yp0u4dKPfli3CYq0O13Ih71mylJ80tOi10On8wi+F4+LWgDPeJ30msSQt9/vkmHq9/Lvo2b461mP801v3W4xTcs6CbvF9UDdrSt+A8OUbpSh55qAUFXWznBBfdeJ8a4d7ugT5tvxUza3h9m4H7ptTqiG4z0g5dc0X29OcGlhpGFMpQo9ytTS+NViZpNdvU4kWx+LKxNY10kQ1yqGXrhe4/1nvP7E+nd5A92TtaRplbHSqoIdOqtRWti+fkB5/n1+/VvCmz12pG1kpQWsfi1ftlBobm0bpngs16CHkbIwdLnParxtTV3QYRlfJ0KFskH7pdN/YDn+yRuSd7sNH3aO0DYPggk6uWuXrfOc+fa3VTxFVvKaNxHsiHmsXyCLIE5yuOeN3/Jdf8HBL/5M6shjyhxHx9BjB1O0+4NLOnjLLSxwO7ukN4jMbOIcD879KLSi6Pk61Oqm2377n8079PXEEQ7cy7OKEC9nbpet118fxweTafpt69x/Bt8UqGzNQt7aelpc44dn5cqhwf71+qKp/Zf/+a0zcizOUWpl/iBcSXip0pplkatCchoH5c5aUM8I7/dWxAej8WicPL1URFZ9BDJelUwEwTkGqUhgSlydVes95YdXvhh9Gfz/aeFWvgVb4tuLbcv4+wLdutVZv/cUonwBD/6eDlE0aSiKK/uoH3+J1wDE/jMVqY2ysGufN84oIXB0sPzy8ollX/LegY74DgJXJR57sn+VGza0x3DnuIgABFM15LmajjjsNlYj+JEZGbuRYcAMOWxFkPN2w6Wd46xo4gVWQR/X4lyI/R6K/YK0110GzudPRW7Y+UOBGTfNNzHeYT0fiH0taunBpq9HEW8OKSaBGj21L0MqenEmNRWBAWDWAk4CpNoEZJ2tTaPFgbQYj8HxtFilErs3BTRwT8uO1NXQaWfIotchmPkAF5mMBAliEmZiOGVgCG9LgRzpscMAOOwowlT3JhusdazXGSC/hxR3UlmWVwWHpOIKheqONvjyhSiTHIkVUco5bnji8m//zL7PKaT1Vl5I6UE609f+gkr6MZKVyKc7zJRmCahLsdlyA5fdQkRSan9LgnnLEyGSkaKJCJog0wAgvepWBt80+1yKln1bMVtCljfNWDueKLsWwaEbBSfSPTEmVRsUcYYMnEjcjeyCZzBXK9E9BYBXLKjOSpUDR+nEV3TFSUdQaz+ot98QxgXwx0GQ+EEUAKB2qZPkQQ0GqFD8UPFMqyaCHM24BZmSGic9EYMagKizOw9Hz50DMrDLrqqLkTAhplMictiCAx5S3BIUQdeJeLnBy2CNtMfz6cV4u8XKoFZQesbf9YZiIERiHjaNodDW6LgcirX/mPnJIkBGDUpTBhSa0EIr38D5hCIszhCM8URGBqImoWjpvpt1ebu/v3Gl3qJfMnNM+9V+kiRFyROTPHQWOcs1dNW94/ukKMPZBvDi55i5CttdeJz84DLngLqjcdwEZ87bFFR8CIG35OAkDVN6VRDZ7aq67NteYqZ2lpT8oYB2CytoBd6VuAx4WgiAsnuj3WohG+LugzXiQRDeM3XYXlULv4dp5VFYC) format("woff2"),url(/assets/KaTeX_Size3-Regular-CTq5MqoE.woff) format("woff"),url(/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf) format("truetype")}@font-face{font-family:KaTeX_Size4;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2) format("woff2"),url(/assets/KaTeX_Size4-Regular-BF-4gkZK.woff) format("woff"),url(/assets/KaTeX_Size4-Regular-DWFBv043.ttf) format("truetype")}@font-face{font-family:KaTeX_Typewriter;font-style:normal;font-weight:400;src:url(/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2) format("woff2"),url(/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff) format("woff"),url(/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf) format("truetype")}.katex{font: 1.21em KaTeX_Main,Times New Roman,serif;line-height:1.2;text-indent:0;text-rendering:auto}.katex *{-ms-high-contrast-adjust:none!important;border-color:currentColor}.katex .katex-version:after{content:"0.16.22"}.katex .katex-mathml{clip:rect(1px,1px,1px,1px);border:0;height:1px;overflow:hidden;padding:0;position:absolute;width:1px}.katex .katex-html>.newline{display:block}.katex .base{position:relative;white-space:nowrap;width:-webkit-min-content;width:-moz-min-content;width:min-content}.katex .base,.katex .strut{display:inline-block}.katex .textbf{font-weight:700}.katex .textit{font-style:italic}.katex .textrm{font-family:KaTeX_Main}.katex .textsf{font-family:KaTeX_SansSerif}.katex .texttt{font-family:KaTeX_Typewriter}.katex .mathnormal{font-family:KaTeX_Math;font-style:italic}.katex .mathit{font-family:KaTeX_Main;font-style:italic}.katex .mathrm{font-style:normal}.katex .mathbf{font-family:KaTeX_Main;font-weight:700}.katex .boldsymbol{font-family:KaTeX_Math;font-style:italic;font-weight:700}.katex .amsrm,.katex .mathbb,.katex .textbb{font-family:KaTeX_AMS}.katex .mathcal{font-family:KaTeX_Caligraphic}.katex .mathfrak,.katex .textfrak{font-family:KaTeX_Fraktur}.katex .mathboldfrak,.katex .textboldfrak{font-family:KaTeX_Fraktur;font-weight:700}.katex .mathtt{font-family:KaTeX_Typewriter}.katex .mathscr,.katex .textscr{font-family:KaTeX_Script}.katex .mathsf,.katex .textsf{font-family:KaTeX_SansSerif}.katex .mathboldsf,.katex .textboldsf{font-family:KaTeX_SansSerif;font-weight:700}.katex .mathitsf,.katex .mathsfit,.katex .textitsf{font-family:KaTeX_SansSerif;font-style:italic}.katex .mainrm{font-family:KaTeX_Main;font-style:normal}.katex .vlist-t{border-collapse:collapse;display:inline-table;table-layout:fixed}.katex .vlist-r{display:table-row}.katex .vlist{display:table-cell;position:relative;vertical-align:bottom}.katex .vlist>span{display:block;height:0;position:relative}.katex .vlist>span>span{display:inline-block}.katex .vlist>span>.pstrut{overflow:hidden;width:0}.katex .vlist-t2{margin-right:-2px}.katex .vlist-s{display:table-cell;font-size:1px;min-width:2px;vertical-align:bottom;width:2px}.katex .vbox{align-items:baseline;display:inline-flex;flex-direction:column}.katex .hbox{width:100%}.katex .hbox,.katex .thinbox{display:inline-flex;flex-direction:row}.katex .thinbox{max-width:0;width:0}.katex .msupsub{text-align:left}.katex .mfrac>span>span{text-align:center}.katex .mfrac .frac-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline,.katex .hline,.katex .mfrac .frac-line,.katex .overline .overline-line,.katex .rule,.katex .underline .underline-line{min-height:1px}.katex .mspace{display:inline-block}.katex .clap,.katex .llap,.katex .rlap{position:relative;width:0}.katex .clap>.inner,.katex .llap>.inner,.katex .rlap>.inner{position:absolute}.katex .clap>.fix,.katex .llap>.fix,.katex .rlap>.fix{display:inline-block}.katex .llap>.inner{right:0}.katex .clap>.inner,.katex .rlap>.inner{left:0}.katex .clap>.inner>span{margin-left:-50%;margin-right:50%}.katex .rule{border:0 solid;display:inline-block;position:relative}.katex .hline,.katex .overline .overline-line,.katex .underline .underline-line{border-bottom-style:solid;display:inline-block;width:100%}.katex .hdashline{border-bottom-style:dashed;display:inline-block;width:100%}.katex .sqrt>.root{margin-left:.2777777778em;margin-right:-.5555555556em}.katex .fontsize-ensurer.reset-size1.size1,.katex .sizing.reset-size1.size1{font-size:1em}.katex .fontsize-ensurer.reset-size1.size2,.katex .sizing.reset-size1.size2{font-size:1.2em}.katex .fontsize-ensurer.reset-size1.size3,.katex .sizing.reset-size1.size3{font-size:1.4em}.katex .fontsize-ensurer.reset-size1.size4,.katex .sizing.reset-size1.size4{font-size:1.6em}.katex .fontsize-ensurer.reset-size1.size5,.katex .sizing.reset-size1.size5{font-size:1.8em}.katex .fontsize-ensurer.reset-size1.size6,.katex .sizing.reset-size1.size6{font-size:2em}.katex .fontsize-ensurer.reset-size1.size7,.katex .sizing.reset-size1.size7{font-size:2.4em}.katex .fontsize-ensurer.reset-size1.size8,.katex .sizing.reset-size1.size8{font-size:2.88em}.katex .fontsize-ensurer.reset-size1.size9,.katex .sizing.reset-size1.size9{font-size:3.456em}.katex .fontsize-ensurer.reset-size1.size10,.katex .sizing.reset-size1.size10{font-size:4.148em}.katex .fontsize-ensurer.reset-size1.size11,.katex .sizing.reset-size1.size11{font-size:4.976em}.katex .fontsize-ensurer.reset-size2.size1,.katex .sizing.reset-size2.size1{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size2.size2,.katex .sizing.reset-size2.size2{font-size:1em}.katex .fontsize-ensurer.reset-size2.size3,.katex .sizing.reset-size2.size3{font-size:1.1666666667em}.katex .fontsize-ensurer.reset-size2.size4,.katex .sizing.reset-size2.size4{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size2.size5,.katex .sizing.reset-size2.size5{font-size:1.5em}.katex .fontsize-ensurer.reset-size2.size6,.katex .sizing.reset-size2.size6{font-size:1.6666666667em}.katex .fontsize-ensurer.reset-size2.size7,.katex .sizing.reset-size2.size7{font-size:2em}.katex .fontsize-ensurer.reset-size2.size8,.katex .sizing.reset-size2.size8{font-size:2.4em}.katex .fontsize-ensurer.reset-size2.size9,.katex .sizing.reset-size2.size9{font-size:2.88em}.katex .fontsize-ensurer.reset-size2.size10,.katex .sizing.reset-size2.size10{font-size:3.4566666667em}.katex .fontsize-ensurer.reset-size2.size11,.katex .sizing.reset-size2.size11{font-size:4.1466666667em}.katex .fontsize-ensurer.reset-size3.size1,.katex .sizing.reset-size3.size1{font-size:.7142857143em}.katex .fontsize-ensurer.reset-size3.size2,.katex .sizing.reset-size3.size2{font-size:.8571428571em}.katex .fontsize-ensurer.reset-size3.size3,.katex .sizing.reset-size3.size3{font-size:1em}.katex .fontsize-ensurer.reset-size3.size4,.katex .sizing.reset-size3.size4{font-size:1.1428571429em}.katex .fontsize-ensurer.reset-size3.size5,.katex .sizing.reset-size3.size5{font-size:1.2857142857em}.katex .fontsize-ensurer.reset-size3.size6,.katex .sizing.reset-size3.size6{font-size:1.4285714286em}.katex .fontsize-ensurer.reset-size3.size7,.katex .sizing.reset-size3.size7{font-size:1.7142857143em}.katex .fontsize-ensurer.reset-size3.size8,.katex .sizing.reset-size3.size8{font-size:2.0571428571em}.katex .fontsize-ensurer.reset-size3.size9,.katex .sizing.reset-size3.size9{font-size:2.4685714286em}.katex .fontsize-ensurer.reset-size3.size10,.katex .sizing.reset-size3.size10{font-size:2.9628571429em}.katex .fontsize-ensurer.reset-size3.size11,.katex .sizing.reset-size3.size11{font-size:3.5542857143em}.katex .fontsize-ensurer.reset-size4.size1,.katex .sizing.reset-size4.size1{font-size:.625em}.katex .fontsize-ensurer.reset-size4.size2,.katex .sizing.reset-size4.size2{font-size:.75em}.katex .fontsize-ensurer.reset-size4.size3,.katex .sizing.reset-size4.size3{font-size:.875em}.katex .fontsize-ensurer.reset-size4.size4,.katex .sizing.reset-size4.size4{font-size:1em}.katex .fontsize-ensurer.reset-size4.size5,.katex .sizing.reset-size4.size5{font-size:1.125em}.katex .fontsize-ensurer.reset-size4.size6,.katex .sizing.reset-size4.size6{font-size:1.25em}.katex .fontsize-ensurer.reset-size4.size7,.katex .sizing.reset-size4.size7{font-size:1.5em}.katex .fontsize-ensurer.reset-size4.size8,.katex .sizing.reset-size4.size8{font-size:1.8em}.katex .fontsize-ensurer.reset-size4.size9,.katex .sizing.reset-size4.size9{font-size:2.16em}.katex .fontsize-ensurer.reset-size4.size10,.katex .sizing.reset-size4.size10{font-size:2.5925em}.katex .fontsize-ensurer.reset-size4.size11,.katex .sizing.reset-size4.size11{font-size:3.11em}.katex .fontsize-ensurer.reset-size5.size1,.katex .sizing.reset-size5.size1{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size5.size2,.katex .sizing.reset-size5.size2{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size5.size3,.katex .sizing.reset-size5.size3{font-size:.7777777778em}.katex .fontsize-ensurer.reset-size5.size4,.katex .sizing.reset-size5.size4{font-size:.8888888889em}.katex .fontsize-ensurer.reset-size5.size5,.katex .sizing.reset-size5.size5{font-size:1em}.katex .fontsize-ensurer.reset-size5.size6,.katex .sizing.reset-size5.size6{font-size:1.1111111111em}.katex .fontsize-ensurer.reset-size5.size7,.katex .sizing.reset-size5.size7{font-size:1.3333333333em}.katex .fontsize-ensurer.reset-size5.size8,.katex .sizing.reset-size5.size8{font-size:1.6em}.katex .fontsize-ensurer.reset-size5.size9,.katex .sizing.reset-size5.size9{font-size:1.92em}.katex .fontsize-ensurer.reset-size5.size10,.katex .sizing.reset-size5.size10{font-size:2.3044444444em}.katex .fontsize-ensurer.reset-size5.size11,.katex .sizing.reset-size5.size11{font-size:2.7644444444em}.katex .fontsize-ensurer.reset-size6.size1,.katex .sizing.reset-size6.size1{font-size:.5em}.katex .fontsize-ensurer.reset-size6.size2,.katex .sizing.reset-size6.size2{font-size:.6em}.katex .fontsize-ensurer.reset-size6.size3,.katex .sizing.reset-size6.size3{font-size:.7em}.katex .fontsize-ensurer.reset-size6.size4,.katex .sizing.reset-size6.size4{font-size:.8em}.katex .fontsize-ensurer.reset-size6.size5,.katex .sizing.reset-size6.size5{font-size:.9em}.katex .fontsize-ensurer.reset-size6.size6,.katex .sizing.reset-size6.size6{font-size:1em}.katex .fontsize-ensurer.reset-size6.size7,.katex .sizing.reset-size6.size7{font-size:1.2em}.katex .fontsize-ensurer.reset-size6.size8,.katex .sizing.reset-size6.size8{font-size:1.44em}.katex .fontsize-ensurer.reset-size6.size9,.katex .sizing.reset-size6.size9{font-size:1.728em}.katex .fontsize-ensurer.reset-size6.size10,.katex .sizing.reset-size6.size10{font-size:2.074em}.katex .fontsize-ensurer.reset-size6.size11,.katex .sizing.reset-size6.size11{font-size:2.488em}.katex .fontsize-ensurer.reset-size7.size1,.katex .sizing.reset-size7.size1{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size7.size2,.katex .sizing.reset-size7.size2{font-size:.5em}.katex .fontsize-ensurer.reset-size7.size3,.katex .sizing.reset-size7.size3{font-size:.5833333333em}.katex .fontsize-ensurer.reset-size7.size4,.katex .sizing.reset-size7.size4{font-size:.6666666667em}.katex .fontsize-ensurer.reset-size7.size5,.katex .sizing.reset-size7.size5{font-size:.75em}.katex .fontsize-ensurer.reset-size7.size6,.katex .sizing.reset-size7.size6{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size7.size7,.katex .sizing.reset-size7.size7{font-size:1em}.katex .fontsize-ensurer.reset-size7.size8,.katex .sizing.reset-size7.size8{font-size:1.2em}.katex .fontsize-ensurer.reset-size7.size9,.katex .sizing.reset-size7.size9{font-size:1.44em}.katex .fontsize-ensurer.reset-size7.size10,.katex .sizing.reset-size7.size10{font-size:1.7283333333em}.katex .fontsize-ensurer.reset-size7.size11,.katex .sizing.reset-size7.size11{font-size:2.0733333333em}.katex .fontsize-ensurer.reset-size8.size1,.katex .sizing.reset-size8.size1{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size8.size2,.katex .sizing.reset-size8.size2{font-size:.4166666667em}.katex .fontsize-ensurer.reset-size8.size3,.katex .sizing.reset-size8.size3{font-size:.4861111111em}.katex .fontsize-ensurer.reset-size8.size4,.katex .sizing.reset-size8.size4{font-size:.5555555556em}.katex .fontsize-ensurer.reset-size8.size5,.katex .sizing.reset-size8.size5{font-size:.625em}.katex .fontsize-ensurer.reset-size8.size6,.katex .sizing.reset-size8.size6{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size8.size7,.katex .sizing.reset-size8.size7{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size8.size8,.katex .sizing.reset-size8.size8{font-size:1em}.katex .fontsize-ensurer.reset-size8.size9,.katex .sizing.reset-size8.size9{font-size:1.2em}.katex .fontsize-ensurer.reset-size8.size10,.katex .sizing.reset-size8.size10{font-size:1.4402777778em}.katex .fontsize-ensurer.reset-size8.size11,.katex .sizing.reset-size8.size11{font-size:1.7277777778em}.katex .fontsize-ensurer.reset-size9.size1,.katex .sizing.reset-size9.size1{font-size:.2893518519em}.katex .fontsize-ensurer.reset-size9.size2,.katex .sizing.reset-size9.size2{font-size:.3472222222em}.katex .fontsize-ensurer.reset-size9.size3,.katex .sizing.reset-size9.size3{font-size:.4050925926em}.katex .fontsize-ensurer.reset-size9.size4,.katex .sizing.reset-size9.size4{font-size:.462962963em}.katex .fontsize-ensurer.reset-size9.size5,.katex .sizing.reset-size9.size5{font-size:.5208333333em}.katex .fontsize-ensurer.reset-size9.size6,.katex .sizing.reset-size9.size6{font-size:.5787037037em}.katex .fontsize-ensurer.reset-size9.size7,.katex .sizing.reset-size9.size7{font-size:.6944444444em}.katex .fontsize-ensurer.reset-size9.size8,.katex .sizing.reset-size9.size8{font-size:.8333333333em}.katex .fontsize-ensurer.reset-size9.size9,.katex .sizing.reset-size9.size9{font-size:1em}.katex .fontsize-ensurer.reset-size9.size10,.katex .sizing.reset-size9.size10{font-size:1.2002314815em}.katex .fontsize-ensurer.reset-size9.size11,.katex .sizing.reset-size9.size11{font-size:1.4398148148em}.katex .fontsize-ensurer.reset-size10.size1,.katex .sizing.reset-size10.size1{font-size:.2410800386em}.katex .fontsize-ensurer.reset-size10.size2,.katex .sizing.reset-size10.size2{font-size:.2892960463em}.katex .fontsize-ensurer.reset-size10.size3,.katex .sizing.reset-size10.size3{font-size:.337512054em}.katex .fontsize-ensurer.reset-size10.size4,.katex .sizing.reset-size10.size4{font-size:.3857280617em}.katex .fontsize-ensurer.reset-size10.size5,.katex .sizing.reset-size10.size5{font-size:.4339440694em}.katex .fontsize-ensurer.reset-size10.size6,.katex .sizing.reset-size10.size6{font-size:.4821600771em}.katex .fontsize-ensurer.reset-size10.size7,.katex .sizing.reset-size10.size7{font-size:.5785920926em}.katex .fontsize-ensurer.reset-size10.size8,.katex .sizing.reset-size10.size8{font-size:.6943105111em}.katex .fontsize-ensurer.reset-size10.size9,.katex .sizing.reset-size10.size9{font-size:.8331726133em}.katex .fontsize-ensurer.reset-size10.size10,.katex .sizing.reset-size10.size10{font-size:1em}.katex .fontsize-ensurer.reset-size10.size11,.katex .sizing.reset-size10.size11{font-size:1.1996142719em}.katex .fontsize-ensurer.reset-size11.size1,.katex .sizing.reset-size11.size1{font-size:.2009646302em}.katex .fontsize-ensurer.reset-size11.size2,.katex .sizing.reset-size11.size2{font-size:.2411575563em}.katex .fontsize-ensurer.reset-size11.size3,.katex .sizing.reset-size11.size3{font-size:.2813504823em}.katex .fontsize-ensurer.reset-size11.size4,.katex .sizing.reset-size11.size4{font-size:.3215434084em}.katex .fontsize-ensurer.reset-size11.size5,.katex .sizing.reset-size11.size5{font-size:.3617363344em}.katex .fontsize-ensurer.reset-size11.size6,.katex .sizing.reset-size11.size6{font-size:.4019292605em}.katex .fontsize-ensurer.reset-size11.size7,.katex .sizing.reset-size11.size7{font-size:.4823151125em}.katex .fontsize-ensurer.reset-size11.size8,.katex .sizing.reset-size11.size8{font-size:.578778135em}.katex .fontsize-ensurer.reset-size11.size9,.katex .sizing.reset-size11.size9{font-size:.6945337621em}.katex .fontsize-ensurer.reset-size11.size10,.katex .sizing.reset-size11.size10{font-size:.8336012862em}.katex .fontsize-ensurer.reset-size11.size11,.katex .sizing.reset-size11.size11{font-size:1em}.katex .delimsizing.size1{font-family:KaTeX_Size1}.katex .delimsizing.size2{font-family:KaTeX_Size2}.katex .delimsizing.size3{font-family:KaTeX_Size3}.katex .delimsizing.size4{font-family:KaTeX_Size4}.katex .delimsizing.mult .delim-size1>span{font-family:KaTeX_Size1}.katex .delimsizing.mult .delim-size4>span{font-family:KaTeX_Size4}.katex .nulldelimiter{display:inline-block;width:.12em}.katex .delimcenter,.katex .op-symbol{position:relative}.katex .op-symbol.small-op{font-family:KaTeX_Size1}.katex .op-symbol.large-op{font-family:KaTeX_Size2}.katex .accent>.vlist-t,.katex .op-limits>.vlist-t{text-align:center}.katex .accent .accent-body{position:relative}.katex .accent .accent-body:not(.accent-full){width:0}.katex .overlay{display:block}.katex .mtable .vertical-separator{display:inline-block;min-width:1px}.katex .mtable .arraycolsep{display:inline-block}.katex .mtable .col-align-c>.vlist-t{text-align:center}.katex .mtable .col-align-l>.vlist-t{text-align:left}.katex .mtable .col-align-r>.vlist-t{text-align:right}.katex .svg-align{text-align:left}.katex svg{fill:currentColor;stroke:currentColor;fill-rule:nonzero;fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke-miterlimit:4;stroke-dasharray:none;stroke-dashoffset:0;stroke-opacity:1;display:block;height:inherit;position:absolute;width:100%}.katex svg path{stroke:none}.katex img{border-style:none;max-height:none;max-width:none;min-height:0;min-width:0}.katex .stretchy{display:block;overflow:hidden;position:relative;width:100%}.katex .stretchy:after,.katex .stretchy:before{content:""}.katex .hide-tail{overflow:hidden;position:relative;width:100%}.katex .halfarrow-left{left:0;overflow:hidden;position:absolute;width:50.2%}.katex .halfarrow-right{overflow:hidden;position:absolute;right:0;width:50.2%}.katex .brace-left{left:0;overflow:hidden;position:absolute;width:25.1%}.katex .brace-center{left:25%;overflow:hidden;position:absolute;width:50%}.katex .brace-right{overflow:hidden;position:absolute;right:0;width:25.1%}.katex .x-arrow-pad{padding:0 .5em}.katex .cd-arrow-pad{padding:0 .55556em 0 .27778em}.katex .mover,.katex .munder,.katex .x-arrow{text-align:center}.katex .boxpad{padding:0 .3em}.katex .fbox,.katex .fcolorbox{border:.04em solid;box-sizing:border-box}.katex .cancel-pad{padding:0 .2em}.katex .cancel-lap{margin-left:-.2em;margin-right:-.2em}.katex .sout{border-bottom-style:solid;border-bottom-width:.08em}.katex .angl{border-right:.049em solid;border-top:.049em solid;box-sizing:border-box;margin-right:.03889em}.katex .anglpad{padding:0 .03889em}.katex .eqn-num:before{content:"(" counter(katexEqnNo) ")";counter-increment:katexEqnNo}.katex .mml-eqn-num:before{content:"(" counter(mmlEqnNo) ")";counter-increment:mmlEqnNo}.katex .mtr-glue{width:50%}.katex .cd-vert-arrow{display:inline-block;position:relative}.katex .cd-label-left{display:inline-block;position:absolute;right:calc(50% + .3em);text-align:left}.katex .cd-label-right{display:inline-block;left:calc(50% + .3em);position:absolute;text-align:right}.katex-display{display:block;margin:1em 0;text-align:center}.katex-display>.katex{display:block;text-align:center;white-space:nowrap}.katex-display>.katex>.katex-html{display:block;position:relative}.katex-display>.katex>.katex-html>.tag{position:absolute;right:0}.katex-display.leqno>.katex>.katex-html>.tag{left:0;right:auto}.katex-display.fleqn>.katex{padding-left:2em;text-align:left}body{counter-reset:katexEqnNo mmlEqnNo}.assignments-section{margin-top:30px}.section-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.section-header-row h2{margin:0;font-size:24px;color:#2d3748;font-weight:600}.create-assignment-btn{background:#4f46e5;color:#fff;border:none;padding:10px 20px;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:8px;box-shadow:0 2px 4px #0000000d}.create-assignment-btn:hover{background:#4338ca}.create-first-btn{background:#f9fafb;border:1px solid #e5e7eb;color:#4f46e5;padding:8px 16px;border-radius:6px;font-weight:500;margin-top:15px;cursor:pointer;transition:all .2s}.create-first-btn:hover{background:#f3f4f6;border-color:#d1d5db}.no-assignments{text-align:center;padding:40px 20px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000000d}.no-assignments p{color:#6b7280;margin-bottom:15px}.assignments-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.assignment-card{background:#fff;border-radius:10px;overflow:hidden;box-shadow:0 4px 6px #0000000a;transition:transform .2s,box-shadow .2s;cursor:pointer;border:1px solid #e5e7eb}.assignment-card:hover{transform:translateY(-3px);box-shadow:0 10px 15px #00000014}.assignment-icon{background:#f0f5ff;padding:20px;display:flex;justify-content:center;font-size:32px;color:#4f46e5}.assignment-details{padding:20px}.assignment-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.assignment-header h3{margin:0;font-size:18px;color:#1f2937;font-weight:600;flex:1}.assignment-description{color:#6b7280;font-size:14px;line-height:1.5;margin-bottom:20px}.assignment-meta{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px}.meta-row{display:flex;flex-direction:column}.meta-label{font-size:12px;color:#9ca3af;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.meta-value{font-size:14px;color:#4b5563;font-weight:500}.badge{display:inline-block;padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.badge-draft{background:#f3f4f6;color:#6b7280}.badge-available{background:#dcfce7;color:#166534}.badge-upcoming{background:#fffbeb;color:#b45309}.badge-urgent{background:#fee2e2;color:#b91c1c}.badge-overdue{background:#f3f4f6;color:#4b5563}.badge-locked{background:#ede9fe;color:#5b21b6}.badge-closed{background:#e5e7eb;color:#4b5563}.assignment-actions{padding:15px 20px;background:#f9fafb;border-top:1px solid #e5e7eb;display:flex;gap:12px}.action-btn{flex:1;padding:8px 12px;border-radius:6px;font-weight:500;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .2s}.edit-btn{background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.edit-btn:hover{background:#e5e7eb}.publish-btn{background:#4f46e5;color:#fff;border:1px solid #4f46e5}.publish-btn:hover{background:#4338ca}@media (max-width: 768px){.assignments-list{grid-template-columns:1fr}.section-header-row{flex-direction:column;align-items:flex-start;gap:15px}.assignment-meta{grid-template-columns:1fr}}@media (max-width: 480px){.assignment-actions{flex-direction:column}}:root{--primary-blue: #2563eb;--primary-blue-hover: #1d4ed8;--primary-blue-light: #eff6ff;--primary-blue-lighter: #f0f9ff;--secondary-blue: #3b82f6;--accent-blue: #60a5fa;--dark-blue: #1e40af;--success-color: #22c55e;--warning-color: #facc15;--danger-color: #ef4444;--info-color: #06b6d4;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--white: #ffffff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--border-color: #e2e8f0;--background: #ffffff;--card-background: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--shadow-blue: 0 4px 14px 0 rgba(37, 99, 235, .15);--transition: all .3s cubic-bezier(.4, 0, .2, 1)}*{box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--white);margin:0;padding:0}.quiz-review-page{max-width:1400px;margin:0 auto;padding:32px;background:var(--white);min-height:100vh;animation:fadeIn .5s ease-in}.page-header{margin-bottom:32px}.breadcrumbs{font-size:14px;margin-bottom:24px;display:flex;align-items:center;gap:8px}.breadcrumb-link{color:var(--primary-blue);text-decoration:none;font-weight:500;transition:var(--transition);padding:4px 8px;border-radius:6px;cursor:pointer}.breadcrumb-link:hover{background:var(--primary-blue-lighter);color:var(--primary-blue-hover)}.breadcrumb-separator{color:var(--gray-300);font-size:18px}.quiz-header{background:var(--white);border-radius:16px;padding:32px;box-shadow:var(--shadow-sm);border:1px solid var(--gray-200);position:relative;overflow:hidden}.quiz-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--primary-blue),var(--accent-blue))}.quiz-header h1{margin:0 0 12px;font-size:32px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.quiz-description{font-size:16px;color:var(--text-secondary);margin:0 0 20px;line-height:1.6}.quiz-meta{display:flex;flex-wrap:wrap;gap:16px}.quiz-meta span{display:inline-flex;align-items:center;padding:8px 16px;background:var(--gray-50);border-radius:8px;font-size:14px;font-weight:500;color:var(--text-secondary)}.course-tag{background:var(--primary-blue-lighter)!important;color:var(--primary-blue)!important;border:1px solid var(--accent-blue)}.points-tag{background:var(--gray-50)!important;color:var(--text-primary)!important;font-weight:600!important}.statistics-section{margin-bottom:32px}.statistics-section h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.stat-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:24px;box-shadow:var(--shadow-sm);transition:var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--accent-blue)}.stat-card h3{font-size:14px;font-weight:600;color:var(--text-muted);margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}.stat-value{font-size:32px;font-weight:700;color:var(--primary-blue);margin:0 0 8px}.stat-subtitle{font-size:14px;color:var(--text-secondary)}.grade-distribution{display:flex;gap:16px;flex-wrap:wrap}.grade-item{display:flex;align-items:center;gap:8px;padding:6px 12px;background:var(--gray-50);border-radius:8px}.grade-letter{font-weight:700;font-size:16px}.grade-count{font-size:14px;color:var(--text-secondary)}.controls-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding:20px;background:var(--gray-50);border-radius:12px;flex-wrap:wrap;gap:16px}.filters{display:flex;gap:12px;flex-wrap:wrap}.filter-select,.sort-select{padding:10px 16px;border:2px solid var(--gray-200);border-radius:8px;font-size:14px;background:var(--white);color:var(--text-primary);cursor:pointer;transition:var(--transition)}.filter-select:hover,.sort-select:hover{border-color:var(--primary-blue);background:var(--primary-blue-lighter)}.filter-select:focus,.sort-select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2563eb1a}.action-buttons{display:flex;gap:12px;flex-wrap:wrap}.export-btn,.email-btn{padding:10px 20px;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:8px}.export-btn{background:var(--white);color:var(--primary-blue);border:2px solid var(--primary-blue)}.export-btn:hover{background:var(--primary-blue);color:var(--white);transform:translateY(-2px)}.email-btn{background:var(--primary-blue);color:var(--white)}.email-btn:hover{background:var(--primary-blue-hover);transform:translateY(-2px);box-shadow:var(--shadow-blue)}.students-section{margin-bottom:32px}.students-section h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.students-list{display:flex;flex-direction:column;gap:16px}.student-card{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:20px;cursor:pointer;transition:var(--transition);display:flex;align-items:center;gap:20px;position:relative;box-shadow:var(--shadow-sm)}.student-card:hover{transform:translate(4px);box-shadow:var(--shadow-md);border-color:var(--accent-blue)}.student-card.selected{background:var(--primary-blue-lighter);border-color:var(--primary-blue);box-shadow:var(--shadow-blue)}.student-info{display:flex;align-items:center;gap:16px;flex:1}.student-avatar{width:48px;height:48px;border-radius:50%;overflow:hidden;flex-shrink:0}.student-avatar img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:linear-gradient(135deg,var(--primary-blue),var(--accent-blue));color:var(--white);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:600}.student-details h3{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.student-details p{margin:0;font-size:14px;color:var(--text-secondary)}.submission-status,.submitted-info{display:flex;align-items:center;gap:16px}.score{display:flex;flex-direction:column;align-items:center}.score-value{font-size:18px;font-weight:700;color:var(--primary-blue)}.percentage{font-size:14px;color:var(--text-secondary)}.letter-grade{padding:8px 16px;border-radius:8px;color:var(--white);font-weight:700;font-size:16px}.submission-time{font-size:13px;color:var(--text-muted)}.status-badge{padding:8px 16px;border-radius:8px;font-size:14px;font-weight:600}.status-badge.not-submitted{background:var(--gray-100);color:var(--text-secondary);border:1px solid var(--gray-300)}.expand-icon{font-size:14px;color:var(--primary-blue);transition:var(--transition)}.student-card.selected .expand-icon{transform:rotate(180deg)}.student-detail-section{background:var(--white);border:1px solid var(--gray-200);border-radius:16px;padding:32px;margin-top:32px;box-shadow:var(--shadow-md);animation:slideDown .3s ease-out}.student-detail-section h2{font-size:24px;font-weight:600;color:var(--text-primary);margin:0 0 24px;padding-bottom:16px;border-bottom:2px solid var(--gray-100)}.submission-details{animation:fadeIn .3s ease-in}.submission-header{margin-bottom:32px}.submission-meta{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:20px}.teacher-feedback{background:var(--gray-50);border-left:4px solid var(--primary-blue);padding:16px 20px;border-radius:8px;margin-top:20px}.teacher-feedback p{margin:0;color:var(--text-secondary);line-height:1.6}.answers-review{margin-top:32px}.answers-review h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.question-review{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:24px;margin-bottom:16px;transition:var(--transition)}.question-review:hover{box-shadow:var(--shadow-sm);border-color:var(--accent-blue)}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--gray-100)}.question-content{margin-top:16px}.student-answer p,.correct-answer p{margin:0;font-size:14px;color:var(--text-primary);line-height:1.5}.answer-feedback p{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5}.loading{display:flex;justify-content:center;align-items:center;min-height:400px;font-size:18px;color:var(--text-secondary);flex-direction:column;gap:20px}.loading:before{content:"";width:48px;height:48px;border:4px solid var(--gray-200);border-top:4px solid var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite}.error{background:#fef2f2;border:2px solid var(--danger-color);border-radius:12px;padding:24px;margin:32px auto;text-align:center;color:var(--danger-color);font-size:16px;font-weight:500;max-width:600px}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 1024px){.quiz-review-page{padding:24px}.stats-grid{grid-template-columns:repeat(2,1fr)}.answer-comparison{grid-template-columns:1fr}}@media (max-width: 768px){.quiz-review-page{padding:16px}.quiz-header{padding:24px}.quiz-header h1{font-size:24px}.controls-section{flex-direction:column;align-items:stretch}.filters,.filter-select,.sort-select,.action-buttons{width:100%}.export-btn,.email-btn{flex:1}.stats-grid{grid-template-columns:1fr}.student-card{flex-direction:column;align-items:flex-start}.submission-status{width:100%;margin-top:16px;padding-top:16px;border-top:1px solid var(--gray-200)}.submitted-info{width:100%;justify-content:space-between}.expand-icon{position:absolute;top:20px;right:20px}.student-detail-section{padding:24px}.submission-meta{flex-direction:column;gap:12px}.submission-meta span{width:100%}}@media (max-width: 480px){.quiz-review-page{padding:12px}.quiz-header{padding:20px}.quiz-header h1{font-size:20px}.quiz-meta{flex-direction:column;gap:8px}.quiz-meta span{width:100%}.stat-card{padding:20px}.stat-value{font-size:24px}.grade-distribution{flex-direction:column;gap:8px}.grade-item{width:100%;justify-content:space-between}.student-card{padding:16px}.student-avatar{width:40px;height:40px}.question-review{padding:16px}.question-header{flex-direction:column;align-items:flex-start;gap:8px}.no-submission{padding:40px 20px}}.search-bar{position:relative;flex:1;max-width:300px}.search-input{width:100%;padding:10px 16px 10px 40px;border:2px solid var(--gray-200);border-radius:8px;font-size:14px;background:var(--white);color:var(--text-primary);transition:var(--transition)}.search-input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2563eb1a}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;z-index:1000;animation:fadeIn .3s ease-in;padding:20px;overflow-y:auto!important;display:flex;align-items:flex-start;justify-content:center}.student-detail-modal{background:var(--white);border-radius:16px;width:90%;max-width:1000px;min-height:auto!important;max-height:none!important;height:auto!important;box-shadow:var(--shadow-xl);animation:slideUp .3s ease-out;margin:20px 0 40px;position:relative}.modal-header{padding:20px 24px;border-bottom:1px solid var(--gray-200);background:var(--white);display:flex;justify-content:space-between;align-items:center;border-top-left-radius:16px;border-top-right-radius:16px}.modal-header h2{margin:0;font-size:20px;flex:1}.close-modal{font-size:28px;cursor:pointer;color:var(--text-secondary);transition:var(--transition);margin-left:20px;line-height:1}.close-modal:hover{color:var(--text-primary)}.modal-content{padding:24px;width:100%;min-height:auto!important;max-height:none!important;overflow:visible!important}.modal-content *{max-height:none!important;overflow:visible!important}.modal-content .question-review{margin-bottom:20px!important;min-height:auto!important;max-height:none!important;overflow:visible!important}.modal-content .answers-review{min-height:auto!important;max-height:none!important;overflow:visible!important}@media (max-width: 768px){.modal-overlay{padding:10px}.student-detail-modal{width:calc(100% - 20px);margin:10px 0 40px}.modal-header{padding:16px 20px}.modal-header h2{font-size:18px}.modal-content{padding:20px}}body.modal-open{overflow:hidden}.modal-overlay.open{overflow-y:auto}.katex-display{margin:1em 0;text-align:center}.question-text .katex,.student-answer .katex,.correct-answer .katex{display:inline-block;margin:0 .2em;vertical-align:middle}.question-content .katex{margin:.5em 0}.katex-wrapper{display:inline-block;max-width:100%;overflow-x:auto;vertical-align:middle}.katex-wrapper .katex{display:inline-block!important;white-space:nowrap;max-width:100%}.katex-wrapper .katex .base{display:inline-block;max-width:100%}.katex .sqrt>.root{border-left:.04em solid;border-top:.04em solid;border-top-left-radius:.2em}.katex .sqrt>.vlist-t{border-left:.04em solid}.katex .sqrt .vlist-t .vlist-r .vlist .pstrut{width:auto!important}.katex-display{margin:1em 0;text-align:center;overflow-x:auto}.katex{font-size:1.1em;line-height:1.2}.question-text .katex-wrapper,.student-answer .katex-wrapper,.correct-answer .katex-wrapper{margin:0 .2em}.latex-error{color:#ef4444;background-color:#fef2f2;padding:.2em .4em;border-radius:.25rem;font-family:monospace}.question-text,.student-answer div,.correct-answer div{word-wrap:break-word;overflow-wrap:break-word}.question-content .katex-wrapper{margin:.2em 0}@media (max-width: 768px){.katex-wrapper{font-size:.9em}.katex-display{font-size:.8em;margin:.5em 0}}.modal-overlay{position:fixed;inset:0;background-color:#0009;z-index:1000;animation:fadeIn .3s ease-in;padding:20px;overflow-y:auto;display:flex;align-items:flex-start;justify-content:center}.student-detail-modal{background:var(--white);border-radius:16px;width:90%;max-width:1000px;box-shadow:var(--shadow-xl);animation:slideUp .3s ease-out;margin:20px auto;position:relative;display:flex;flex-direction:column;min-height:0}.modal-header{padding:20px 24px;border-bottom:1px solid var(--gray-200);background:var(--white);display:flex;justify-content:space-between;align-items:center;border-top-left-radius:16px;border-top-right-radius:16px;flex-shrink:0}.modal-header h2{margin:0;font-size:20px;font-weight:600;color:var(--text-primary);flex:1;display:flex;justify-content:space-between;align-items:center}.close-modal{font-size:28px;cursor:pointer;color:var(--text-secondary);transition:var(--transition);line-height:1;padding:4px;border-radius:4px}.close-modal:hover{color:var(--text-primary);background:var(--gray-100)}.modal-content{padding:24px;overflow-y:auto;flex:1;min-height:0}.submission-details{display:flex;flex-direction:column;gap:24px}.submission-header{border-bottom:1px solid var(--gray-200);padding-bottom:20px}.submission-meta{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:16px}.submission-meta span{display:inline-flex;align-items:center;padding:8px 16px;background:var(--primary-blue-lighter);color:var(--primary-blue);border-radius:8px;font-size:14px;font-weight:500}.teacher-feedback{background:var(--gray-50);border-left:4px solid var(--primary-blue);padding:16px 20px;border-radius:8px}.teacher-feedback h4{margin:0 0 8px;font-size:14px;font-weight:600;color:var(--text-primary);text-transform:uppercase;letter-spacing:.05em}.teacher-feedback div{margin:0;color:var(--text-secondary);line-height:1.6}.modal-content .question-review{background:var(--white);border:1px solid var(--gray-200);border-radius:12px;padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm)}.modal-content .question-review:last-child{margin-bottom:0}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--gray-100);flex-wrap:wrap;gap:12px}.question-number{font-size:14px;font-weight:600;color:var(--primary-blue);padding:4px 12px;background:var(--primary-blue-lighter);border-radius:6px}.question-points{font-size:14px;font-weight:600;color:var(--text-secondary)}.correctness{padding:6px 12px;border-radius:6px;font-size:14px;font-weight:600}.correctness.correct{background:#dcfce7;color:#14532d}.correctness.incorrect{background:#fee2e2;color:#7f1d1d}.question-text{font-size:16px;color:var(--text-primary);margin:0 0 20px;line-height:1.6;font-weight:500}.answer-comparison{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:20px 0}.student-answer,.correct-answer{background:var(--gray-50);padding:16px;border-radius:8px;border:1px solid var(--gray-200)}.student-answer{border-left:3px solid var(--warning-color)}.correct-answer{border-left:3px solid var(--success-color)}.student-answer h5,.correct-answer h5{margin:0 0 8px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.student-answer div,.correct-answer div{margin:0;font-size:14px;color:var(--text-primary);line-height:1.5;word-wrap:break-word;overflow-wrap:break-word}.answer-feedback{background:var(--primary-blue-lighter);border:1px solid var(--accent-blue);padding:16px;border-radius:8px;margin-top:16px}.answer-feedback h5{margin:0 0 8px;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--primary-blue)}.answer-feedback div{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5}.no-submission{text-align:center;padding:60px 40px;background:var(--gray-50);border-radius:12px;border:2px dashed var(--gray-300)}.no-submission p{font-size:16px;color:var(--text-secondary);margin:0 0 24px}.remind-btn{padding:12px 32px;background:var(--primary-blue);color:var(--white);border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.remind-btn:hover{background:var(--primary-blue-hover);transform:translateY(-2px);box-shadow:var(--shadow-blue)}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.modal-overlay{padding:10px}.student-detail-modal{width:calc(100% - 20px);margin:10px auto;max-height:calc(100vh - 20px)}.modal-header{padding:16px 20px}.modal-header h2{font-size:18px}.modal-content{padding:20px}.answer-comparison{grid-template-columns:1fr;gap:16px}.submission-meta{flex-direction:column;gap:8px}.submission-meta span{width:100%;text-align:center}.question-header{flex-direction:column;align-items:flex-start;gap:8px}.no-submission{padding:40px 20px}}@media (max-width: 480px){.modal-overlay{padding:5px}.student-detail-modal{width:calc(100% - 10px);margin:5px auto;max-height:calc(100vh - 10px);border-radius:12px}.modal-header{padding:12px 16px}.modal-header h2{font-size:16px}.modal-content,.question-review{padding:16px}}.score-summary{margin-top:1rem;padding:1rem;background:#f8f9fa;border-radius:8px;border-left:4px solid #007bff}.score-display{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.current-score{font-size:1.25rem;font-weight:600;display:flex;align-items:center;gap:.25rem}.current-score .score{color:#28a745;font-size:1.5rem}.current-score .total{color:#6c757d}.current-score .percentage{color:#6c757d;font-size:1rem;margin-left:.5rem}.ungraded-indicator{color:#fd7e14!important;font-size:1.25rem!important}.grading-status{background:#fff3cd;color:#856404;padding:.25rem .75rem;border-radius:4px;font-size:.875rem;border:1px solid #ffeaa7}.overall-feedback-section{margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.overall-feedback-section h4{margin-bottom:1rem;color:#495057;font-size:1.1rem}.feedback-input-group{display:flex;flex-direction:column;gap:.75rem}.feedback-textarea{width:100%;padding:.75rem;border:1px solid #ced4da;border-radius:4px;font-family:inherit;font-size:.9rem;line-height:1.5;resize:vertical;min-height:80px}.feedback-textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.save-feedback-btn{align-self:flex-start;padding:.5rem 1rem;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.save-feedback-btn:hover:not(:disabled){background:#0056b3}.save-feedback-btn:disabled{background:#6c757d;cursor:not-allowed}.question-review-container{margin-bottom:2rem;padding:1.5rem;border:1px solid #e9ecef;border-radius:8px;background:#fff}.question-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #e9ecef}.question-info{display:flex;align-items:center;gap:.75rem}.question-number{font-weight:600;color:#495057;font-size:1.1rem}.question-points{color:#6c757d;font-size:.9rem}.grading-status-indicator .graded{background:#d4edda;color:#155724;padding:.25rem .75rem;border-radius:4px;font-size:.875rem;border:1px solid #c3e6cb}.grading-status-indicator .needs-grading{background:#fff3cd;color:#856404;padding:.25rem .75rem;border-radius:4px;font-size:.875rem;border:1px solid #ffeaa7}.question-text{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:4px;font-size:1rem;line-height:1.6}.student-answer-section h5{margin-bottom:.75rem;color:#495057;font-size:1rem}.student-answer{margin-bottom:1.5rem;padding:1rem;background:#fff;border:1px solid #e9ecef;border-left:4px solid #007bff;border-radius:4px;font-size:.95rem;line-height:1.6;white-space:pre-wrap}.no-answer{padding:2rem;text-align:center;color:#6c757d;background:#f8f9fa;border-radius:4px;font-style:italic}.manual-grading-section{margin-top:1.5rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.grading-form{display:flex;flex-direction:column;gap:1.25rem}.points-input-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.points-input-group label{font-weight:600;color:#495057;min-width:60px}.points-input{width:80px;padding:.5rem;border:1px solid #ced4da;border-radius:4px;font-size:1rem;text-align:center}.points-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.max-points{color:#6c757d;font-weight:500;font-size:1rem}.feedback-input-group label{font-weight:600;color:#495057;margin-bottom:.5rem}.grading-actions{display:flex;gap:.75rem;flex-wrap:wrap}.save-grade-btn{padding:.75rem 1.5rem;background:#28a745;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s}.save-grade-btn:hover{background:#218838}.cancel-grade-btn{padding:.75rem 1.5rem;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.cancel-grade-btn:hover{background:#545b62}.grading-display{display:flex;flex-direction:column;gap:1rem}.grade-summary{padding:1rem;background:#fff;border-radius:6px;border:1px solid #d4edda}.points-awarded{color:#155724;font-size:1.1rem;margin-bottom:.75rem}.question-feedback{margin-bottom:1rem}.question-feedback strong{display:block;margin-bottom:.5rem;color:#495057}.question-feedback div{padding:.75rem;background:#f8f9fa;border-radius:4px;border-left:3px solid #007bff;font-size:.95rem;line-height:1.5}.edit-grade-btn{align-self:flex-start;padding:.5rem 1rem;background:#ffc107;color:#212529;border:none;border-radius:4px;cursor:pointer;font-size:.875rem;transition:background-color .2s}.edit-grade-btn:hover{background:#e0a800}.ungraded-prompt{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;flex-wrap:wrap;gap:1rem}.ungraded-text{color:#856404;font-weight:500;font-size:.95rem}.grade-now-btn{padding:.625rem 1.25rem;background:#fd7e14;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background-color .2s;white-space:nowrap}.grade-now-btn:hover{background:#e8690b}@media (max-width: 768px){.question-header,.score-display{flex-direction:column;align-items:flex-start;gap:.75rem}.ungraded-prompt{flex-direction:column;align-items:flex-start;text-align:left}.grading-actions{flex-direction:column}.grading-actions button{width:100%}.points-input-group{flex-direction:column;align-items:flex-start}}:root{--modal-overlay: rgba(15, 23, 42, .7);--modal-backdrop-blur: blur(4px)}.modal-overlay{position:fixed;inset:0;background:var(--modal-overlay);backdrop-filter:var(--modal-backdrop-blur);-webkit-backdrop-filter:var(--modal-backdrop-blur);display:flex;align-items:center;justify-content:center;z-index:1000;animation:modalFadeIn .2s ease-out;padding:20px}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-container{background:var(--card-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border-color);width:100%;max-width:480px;max-height:90vh;overflow:hidden;animation:modalSlideIn .3s ease-out;position:relative}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 20px;border-bottom:1px solid var(--border-color);margin-bottom:24px}.modal-title{margin:0;font-size:24px;font-weight:700;color:var(--text-primary);letter-spacing:-.01em}.modal-close-btn{background:none;border:none;font-size:28px;color:var(--text-muted);cursor:pointer;padding:4px;line-height:1;transition:var(--transition);border-radius:var(--radius-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:var(--text-secondary);background:var(--gray-100)}.modal-close-btn:disabled{opacity:.5;cursor:not-allowed}.modal-body{padding:0 24px 24px}.registration-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-label{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.form-input{padding:14px 16px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:16px;color:var(--text-primary);background:var(--white);transition:var(--transition);font-family:inherit}.form-input:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2563eb1a}.form-input:disabled{background:var(--gray-50);color:var(--text-muted);cursor:not-allowed}.form-input::placeholder{color:var(--text-muted)}.form-help-text{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.4}.error-message{display:flex;align-items:center;gap:8px;padding:12px 16px;background:var(--danger-light);color:var(--danger-color);border:1px solid #fca5a5;border-radius:var(--radius-md);font-size:14px;font-weight:500}.error-icon{font-size:16px;flex-shrink:0}.form-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}.cancel-btn{padding:12px 24px;background:var(--white);color:var(--text-secondary);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);min-width:100px}.cancel-btn:hover{background:var(--gray-50);border-color:var(--gray-300);color:var(--text-primary)}.cancel-btn:disabled{opacity:.5;cursor:not-allowed}.submit-btn{padding:12px 24px;background:var(--primary-blue);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);min-width:180px;display:flex;align-items:center;justify-content:center;gap:8px}.submit-btn:hover:not(:disabled){background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-blue)}.submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}.loading-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite;flex-shrink:0}.success-state{text-align:center;padding:32px 20px;animation:successFadeIn .4s ease-out}@keyframes successFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.success-icon{width:64px;height:64px;background:var(--success-color);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:700;margin:0 auto 24px;animation:successBounce .6s ease-out .2s both}@keyframes successBounce{0%{transform:scale(0)}50%{transform:scale(1.1)}to{transform:scale(1)}}.success-title{margin:0 0 16px;font-size:20px;font-weight:700;color:var(--text-primary)}.success-message{font-size:15px;color:var(--text-secondary);line-height:1.5;max-width:320px;margin:0 auto}@media (max-width: 640px){.modal-overlay{padding:16px;align-items:flex-end}.modal-container{max-width:100%;animation:modalSlideUp .3s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.modal-header{padding:20px 20px 16px;margin-bottom:20px}.modal-title{font-size:20px}.modal-body{padding:0 20px 20px}.form-actions{flex-direction:column-reverse;gap:12px}.cancel-btn,.submit-btn{width:100%;min-width:auto;justify-content:center}.success-state{padding:24px 16px}.success-icon{width:56px;height:56px;font-size:24px;margin-bottom:20px}}@media (max-width: 480px){.modal-overlay{padding:12px}.modal-header{padding:16px 16px 12px;margin-bottom:16px}.modal-body{padding:0 16px 16px}.registration-form{gap:20px}.form-input{padding:12px 14px;font-size:16px}}.modal-container:focus{outline:none}@media (prefers-contrast: high){.modal-container,.form-input,.error-message,.submit-btn,.cancel-btn{border-width:2px}}@media (prefers-reduced-motion: reduce){.modal-overlay,.modal-container,.success-state,.success-icon{animation:none}.loading-spinner{animation:none;border-top-color:transparent}.submit-btn:hover:not(:disabled){transform:none}}:root{--primary-blue: #2563eb;--primary-blue-hover: #1d4ed8;--primary-blue-light: #eff6ff;--primary-blue-lighter: #f0f9ff;--secondary-blue: #3b82f6;--accent-blue: #60a5fa;--dark-blue: #1e40af;--success-color: #22c55e;--success-light: #f0fdf4;--warning-color: #facc15;--warning-light: #fefce8;--danger-color: #ef4444;--danger-light: #fef2f2;--info-color: #06b6d4;--info-light: #f0fdfa;--text-primary: #1e293b;--text-secondary: #64748b;--text-muted: #94a3b8;--white: #ffffff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--border-color: #e2e8f0;--background: #f8fafc;--card-background: #ffffff;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .08);--shadow-md: 0 4px 6px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px rgba(0, 0, 0, .1);--shadow-blue: 0 4px 14px 0 rgba(37, 99, 235, .15);--transition: all .3s cubic-bezier(.4, 0, .2, 1);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px}.student-courses-container{max-width:1400px;margin:0 auto;padding:32px;background:var(--background);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}.header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:32px;padding-bottom:24px;border-bottom:2px solid var(--gray-200)}.page-title{margin:0 0 8px;font-size:36px;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.course-count{margin:0;font-size:16px;color:var(--text-secondary);font-weight:500}.refresh-btn{padding:12px 24px;background:var(--primary-blue);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-sm)}.refresh-btn:hover{background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-blue)}.filters-container{background:var(--card-background);border-radius:var(--radius-lg);padding:24px;margin-bottom:32px;box-shadow:var(--shadow-sm);border:1px solid var(--border-color)}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.filter-group{display:flex;flex-direction:column;gap:6px}.filter-label{font-size:14px;font-weight:600;color:var(--text-primary)}.filter-select{padding:12px 16px;border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;color:var(--text-primary);background:var(--white);cursor:pointer;transition:var(--transition)}.filter-select:focus{outline:none;border-color:var(--primary-blue);box-shadow:0 0 0 3px #2563eb1a}.filter-select:hover{border-color:var(--accent-blue)}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:24px;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.course-card{background:var(--card-background);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-color);transition:var(--transition);overflow:hidden;position:relative}.course-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--primary-blue);transform:scaleY(0);transition:transform .3s}.course-card:hover{box-shadow:var(--shadow-blue);transform:translateY(-2px);border-color:var(--accent-blue)}.course-card:hover:before{transform:scaleY(1)}.course-content{padding:24px;display:flex;flex-direction:column;gap:16px;height:100%}.course-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.course-info{flex:1;min-width:0}.course-title{margin:0 0 8px;font-size:20px;font-weight:700;color:var(--text-primary);line-height:1.3;word-wrap:break-word}.course-code{margin:0;font-size:14px;color:var(--primary-blue);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge{padding:6px 14px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.03em;white-space:nowrap;flex-shrink:0}.status-active{background:var(--success-light);color:#14532d;border:1px solid #86efac}.status-completed{background:var(--info-light);color:#0c4a6e;border:1px solid #7dd3fc}.status-dropped{background:var(--danger-light);color:#7f1d1d;border:1px solid #fca5a5}.status-suspended{background:var(--warning-light);color:#713f12;border:1px solid #fde047}.course-description{margin:0;font-size:14px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.teacher-info{padding:12px 16px;background:var(--gray-50);border-radius:var(--radius-md);border-left:3px solid var(--primary-blue)}.teacher-text{margin:0;font-size:14px;color:var(--text-primary)}.teacher-label{font-weight:600;color:var(--text-secondary)}.grade-info{padding:12px 16px;background:var(--primary-blue-lighter);border-radius:var(--radius-md);border:1px solid var(--accent-blue)}.grade-content{display:flex;justify-content:space-between;align-items:center;gap:12px}.grade-text,.score-text{font-size:14px;font-weight:600;color:var(--dark-blue)}.enrollment-date{font-size:13px;color:var(--text-muted);font-style:italic;margin-top:auto;padding-top:8px;border-top:1px solid var(--gray-200)}.course-actions{display:flex;gap:12px;margin-top:auto;padding-top:8px}.primary-btn{flex:1;padding:12px 20px;background:var(--primary-blue);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition);text-align:center}.primary-btn:hover{background:var(--primary-blue-hover);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.secondary-btn{padding:12px 16px;background:var(--white);color:var(--primary-blue);border:2px solid var(--border-color);border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);white-space:nowrap}.secondary-btn:hover{background:var(--primary-blue-lighter);border-color:var(--accent-blue);color:var(--dark-blue)}.empty-state{grid-column:1 / -1;text-align:center;padding:80px 40px;background:var(--card-background);border-radius:var(--radius-lg);border:2px dashed var(--gray-300);margin-top:40px}.empty-icon{font-size:64px;margin-bottom:24px;opacity:.6}.empty-title{margin:0 0 12px;font-size:24px;font-weight:700;color:var(--text-primary)}.empty-message{font-size:16px;color:var(--text-secondary);max-width:400px;margin:0 auto;line-height:1.5}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px;background:var(--background)}.spinner{width:48px;height:48px;border:4px solid var(--gray-200);border-top:4px solid var(--primary-blue);border-radius:50%;animation:spin 1s linear infinite}.error-container{display:flex;justify-content:center;align-items:center;min-height:400px;padding:32px}.error-content{text-align:center;background:var(--card-background);padding:40px;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);border:1px solid var(--danger-color);max-width:500px;width:100%}.error-title{margin:0 0 16px;font-size:24px;font-weight:700;color:var(--danger-color)}.error-message{margin:0 0 24px;font-size:16px;color:var(--text-secondary);line-height:1.5}.error-retry-btn{padding:12px 24px;background:var(--danger-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.error-retry-btn:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 4px 14px #ef444426}@media (max-width: 1200px){.courses-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px}}@media (max-width: 768px){.student-courses-container{padding:24px 16px}.page-title{font-size:28px}.header{flex-direction:column;align-items:flex-start;gap:16px;border-bottom:1px solid var(--gray-200);padding-bottom:16px}.refresh-btn{width:100%;justify-content:center}.filters-container{padding:20px}.filters-grid,.courses-grid{grid-template-columns:1fr;gap:16px}.course-header{flex-direction:column;align-items:flex-start;gap:12px}.status-badge{align-self:flex-start}.course-actions{flex-direction:column;gap:8px}.secondary-btn{text-align:center}.grade-content{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 480px){.student-courses-container{padding:16px 12px}.page-title{font-size:24px}.filters-container{padding:16px}.course-content{padding:20px;gap:14px}.course-title{font-size:18px}.empty-state{padding:40px 20px}.empty-icon{font-size:48px}.empty-title{font-size:20px}.empty-message{font-size:14px}.error-content{padding:30px 20px}}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.spinner{animation:none}}.primary-btn:focus,.secondary-btn:focus,.refresh-btn:focus,.error-retry-btn:focus{outline:2px solid var(--primary-blue);outline-offset:2px}.filter-select:focus{box-shadow:0 0 0 3px #2563eb1a}@media (prefers-contrast: high){.course-card,.status-badge,.primary-btn,.secondary-btn,.refresh-btn{border-width:2px}}.student-courses-container{padding:2rem;max-width:1400px;margin:0 auto}.header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.header-info{flex:1}.page-title{font-size:2rem;font-weight:700;color:#1f2937;margin:0}.course-count{color:#6b7280;font-size:1rem;margin:.5rem 0 0}.pending-count{color:#f59e0b;font-weight:500}.register-btn{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.register-btn:hover{background:#2563eb;transform:translateY(-1px)}.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:2px solid #e5e7eb}.tab{background:none;border:none;padding:.75rem 1rem;font-size:1rem;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease;position:relative;display:flex;align-items:center;gap:.5rem}.tab:hover{color:#3b82f6}.tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.pending-badge{background:#f59e0b;color:#fff;font-size:.75rem;padding:.125rem .375rem;border-radius:9999px;font-weight:600;line-height:1}.courses-grid,.requests-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(400px,1fr));gap:1.5rem}.course-card,.request-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;padding:1.5rem;transition:all .2s ease;height:fit-content}.course-card:hover,.request-card:hover{box-shadow:0 10px 25px -3px #0000001a,0 4px 6px -2px #0000000d;transform:translateY(-2px)}.course-content,.request-content{display:flex;flex-direction:column;gap:1rem}.course-header,.request-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.course-info,.request-info{flex:1}.course-title,.request-title{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0 0 .5rem;line-height:1.3}.course-code,.request-code{font-size:.875rem;color:#6b7280;font-weight:500;margin:0}.status-badge{padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.025em;white-space:nowrap}.status-active{background:#d1fae5;color:#065f46}.status-completed{background:#dbeafe;color:#1e40af}.status-dropped{background:#fed7d7;color:#991b1b}.status-suspended,.status-pending{background:#fef3c7;color:#92400e}.status-approved{background:#d1fae5;color:#065f46}.status-rejected{background:#fed7d7;color:#991b1b}.course-description{color:#4b5563;font-size:.875rem;line-height:1.5;margin:0}.teacher-info,.request-status-info{border-top:1px solid #f3f4f6;padding-top:1rem}.teacher-text,.request-date,.processed-date{margin:0;font-size:.875rem;color:#4b5563}.teacher-label,.date-label{font-weight:500;color:#374151}.grade-info{display:flex;gap:1rem;flex-wrap:wrap}.grade-text,.score-text{margin:0;font-size:.875rem;color:#4b5563}.grade-label,.score-label{font-weight:500;color:#374151}.enrollment-info{border-top:1px solid #f3f4f6;padding-top:1rem}.enrollment-date{margin:0;font-size:.875rem;color:#4b5563}.enrollment-label{font-weight:500;color:#374151}.rejection-reason,.request-notes{background:#f9fafb;border-left:4px solid #f59e0b;padding:.75rem;border-radius:.25rem}.rejection-reason{border-left-color:#dc2626}.rejection-text,.notes-text{margin:0;font-size:.875rem;color:#4b5563}.rejection-label,.notes-label{font-weight:500;color:#374151}.approval-message{color:#065f46;font-weight:500;margin:0;font-size:.875rem}.course-actions,.request-actions{display:flex;gap:.75rem;padding-top:1rem;border-top:1px solid #f3f4f6}.primary-btn{background:#3b82f6;color:#fff;border:none;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.primary-btn:hover{background:#2563eb}.secondary-btn{background:#fff;color:#374151;border:1px solid #d1d5db;padding:.5rem 1rem;border-radius:.375rem;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s ease}.secondary-btn:hover{background:#f9fafb;border-color:#9ca3af}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center;color:#6b7280}.empty-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.empty-title{font-size:1.5rem;font-weight:600;color:#374151;margin:0 0 .5rem}.empty-message{font-size:1rem;margin:0 0 2rem;max-width:500px;line-height:1.5}.empty-action-btn{background:#3b82f6;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease}.empty-action-btn:hover{background:#2563eb;transform:translateY(-1px)}.loading-container{display:flex;justify-content:center;align-items:center;min-height:400px}.spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.error-container{display:flex;justify-content:center;align-items:center;min-height:400px}.error-content{text-align:center;padding:2rem;background:#fff;border:1px solid #fed7d7;border-radius:.75rem;max-width:500px}.error-title{color:#991b1b;font-size:1.25rem;font-weight:600;margin:0 0 1rem}.error-message{color:#4b5563;margin:0 0 1.5rem;line-height:1.5}.error-retry-btn{background:#dc2626;color:#fff;border:none;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;cursor:pointer;transition:all .2s ease}.error-retry-btn:hover{background:#b91c1c}@media (max-width: 768px){.student-courses-container{padding:1rem}.header{flex-direction:column;align-items:stretch;gap:1rem}.courses-grid,.requests-grid{grid-template-columns:1fr}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab{white-space:nowrap;flex-shrink:0}.course-actions,.request-actions{flex-direction:column}.course-header,.request-header{flex-direction:column;align-items:stretch;gap:.75rem}.status-badge{align-self:flex-start}}.assignment-creator{min-height:100vh;background-color:#f9fafb;min-width:100vw;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.header{background-color:#fff;border-bottom:1px solid #e5e7eb}.header-content{max-width:1280px;margin:0 auto;padding:16px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}.header-left{display:flex;align-items:center;gap:16px;flex-wrap:wrap;min-width:0}.title{font-size:24px;font-weight:700;color:#111827;margin:0;word-break:break-word}.badges{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.badge{padding:4px 8px;border-radius:4px;font-size:14px;display:flex;align-items:center;gap:4px;white-space:nowrap}.badge-published{background-color:#dcfce7;color:#166534}.badge-unpublished{background-color:#f3f4f6;color:#374151}.points-display{font-size:14px;color:#6b7280;white-space:nowrap}.header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.btn{padding:8px 16px;border-radius:8px;border:none;cursor:pointer;font-size:14px;font-weight:500;display:flex;align-items:center;gap:8px;transition:background-color .2s;white-space:nowrap;min-height:40px}.btn-secondary{background-color:#fff;color:#374151;border:1px solid #d1d5db}.btn-secondary:hover{background-color:#f9fafb}.btn-success{background-color:#16a34a;color:#fff}.btn-success:hover{background-color:#15803d}.btn-primary{background-color:#2563eb;color:#fff}.btn-primary:hover{background-color:#1d4ed8}.main-content{max-width:1280px;margin:0 auto;padding:24px 16px}.tabs{border-bottom:1px solid #e5e7eb;margin-bottom:24px;overflow-x:auto}.tab-nav{display:flex;gap:32px;min-width:max-content}.tab{padding:8px 4px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-size:14px;font-weight:500;color:#6b7280;transition:all .2s;white-space:nowrap}.tab:hover{color:#374151}.tab.active{color:#2563eb;border-bottom-color:#2563eb}.grid{display:grid;gap:24px}.grid-3{grid-template-columns:2fr 1fr}.card{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;padding:24px}.card-header{font-size:18px;font-weight:600;margin-bottom:16px;color:#111827}.form-label{display:block;font-size:14px;font-weight:500;color:#374151;margin-bottom:4px}.required{color:#dc2626}.form-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;color:#374151;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-textarea{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;color:#374151;resize:vertical;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;font-family:inherit}.form-textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-select{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:14px;background-color:#fff;color:#374151;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.form-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-group{display:flex;flex-direction:column;gap:8px}.checkbox-item{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.checkbox{width:16px;height:16px;accent-color:#2563eb;flex-shrink:0}.advanced-options{margin-top:16px}.advanced-toggle{display:flex;justify-content:space-between;align-items:center;width:100%;background:none;border:none;cursor:pointer;text-align:left;padding:0}.sidebar{display:flex;flex-direction:column;gap:24px}.sidebar-header{font-size:18px;font-weight:600;margin-bottom:16px;color:#111827;display:flex;align-items:center;gap:8px}.sidebar-actions{display:flex;flex-direction:column;gap:12px}.questions-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}.questions-info{font-size:14px;color:#6b7280;margin-top:4px}.empty-state{text-align:center;padding:48px 24px}.empty-icon{color:#9ca3af;margin-bottom:16px}.empty-title{font-size:18px;font-weight:500;color:#111827;margin-bottom:8px}.empty-description{color:#6b7280;margin-bottom:16px}.question-list{display:flex;flex-direction:column;gap:16px}.question-item{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:16px;transition:box-shadow .2s}.question-item:hover{box-shadow:0 4px 6px #0000001a}.question-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px}.question-content{flex:1;min-width:0}.question-title{font-weight:500;margin-bottom:4px;word-break:break-word}.question-meta{font-size:14px;color:#6b7280;margin-bottom:8px}.question-text{font-size:14px;color:#374151;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.question-actions{display:flex;gap:8px;flex-shrink:0}.icon-btn{padding:8px;background:none;border:none;cursor:pointer;border-radius:4px;color:#6b7280;transition:color .2s;display:flex;align-items:center;justify-content:center}.icon-btn:hover{color:#2563eb}.icon-btn.danger:hover{color:#dc2626}.question-editor{background-color:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:24px;margin-bottom:16px}.question-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;gap:16px;flex-wrap:wrap}.question-title-input{font-size:18px;font-weight:600;background:transparent;border:none;outline:none;flex:1;color:#111827;min-width:200px;padding:4px 8px}.question-title-input:focus{background-color:#f9fafb;border-radius:4px}.question-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.points-input{width:64px;padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:14px;text-align:right;background-color:#fff;color:#374151;box-sizing:border-box}.points-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.answer-options{margin-top:16px}.answer-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px;padding:12px;background-color:#f9fafb;border-radius:8px}.correct-btn{width:24px;height:24px;border-radius:50%;border:2px solid #d1d5db;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-top:4px;transition:all .2s;flex-shrink:0}.correct-btn:hover{border-color:#16a34a}.correct-btn.correct{background-color:#16a34a;border-color:#16a34a}.correct-indicator{width:8px;height:8px;background-color:#fff;border-radius:50%}.answer-inputs{flex:1;min-width:0}.answer-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;margin-bottom:8px;background-color:#fff;color:#374151;font-size:14px;box-sizing:border-box}.answer-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.feedback-input{width:100%;padding:8px 12px;border:1px solid #d1d5db;border-radius:8px;font-size:12px;background-color:#fff;color:#374151;box-sizing:border-box}.feedback-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.add-answer{display:flex;align-items:center;gap:8px;color:#2563eb;text-decoration:none;font-size:14px;cursor:pointer;padding:8px 0;background:none;border:none}.add-answer:hover{color:#1d4ed8}.info-box{background-color:#dbeafe;padding:12px;border-radius:8px}.info-text{font-size:14px;color:#1e40af;margin:0}.file-input-hidden{display:none}.image-upload-area{border:2px dashed #d1d5db;border-radius:8px;padding:24px;text-align:center;transition:all .2s}.image-upload-label{display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;color:#6b7280}.image-upload-label:hover{color:#2563eb}.image-upload-area:hover{border-color:#2563eb;background-color:#f0f9ff}.image-upload-hint{font-size:12px;color:#9ca3af}.image-preview-container{position:relative;display:inline-block;max-width:100%}.question-image-preview{max-width:100%;max-height:300px;border-radius:8px;border:1px solid #e5e7eb}.remove-image-btn{position:absolute;top:8px;right:8px;background-color:#00000080;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s}.remove-image-btn:hover{background-color:#000000b3}.question-thumbnail{width:40px;height:40px;object-fit:cover;border-radius:4px;border:1px solid #e5e7eb;margin-top:8px}.bottom-actions{background-color:#fff;border-top:1px solid #e5e7eb;padding:24px;margin-top:32px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap}.notify-checkbox{display:flex;align-items:center;gap:8px}.notify-text{font-size:14px}.bottom-buttons{display:flex;gap:12px;flex-wrap:wrap}.btn-large{padding:12px 24px}@media (max-width: 1024px){.grid-3{grid-template-columns:1fr}.header-content{flex-direction:column;align-items:stretch}.header-left{justify-content:center;text-align:center}.header-actions{justify-content:center}}@media (max-width: 768px){.main-content{padding:16px 8px}.card{padding:16px}.form-row{grid-template-columns:1fr}.question-editor-header{flex-direction:column;align-items:stretch}.question-title-input{min-width:auto;margin-bottom:12px}.question-controls{justify-content:space-between}.questions-header,.bottom-actions{flex-direction:column;align-items:stretch}.bottom-buttons{justify-content:center}.answer-item{flex-direction:column;gap:8px}.correct-btn{align-self:flex-start;margin-top:0}}@media (max-width: 480px){.title{font-size:20px}.btn{padding:10px 12px;font-size:13px}.header-actions{flex-direction:column;width:100%}.header-actions .btn{width:100%;justify-content:center}.tab-nav{gap:16px}.sidebar-actions .btn{width:100%;justify-content:center}}@media print{.header-actions,.bottom-actions,.question-actions,.icon-btn{display:none}.assignment-creator{background:#fff}.card{box-shadow:none;border:1px solid #e5e7eb}}.latex-renderer{font-size:1.1em}.latex-renderer .katex{font-size:1.1em!important}.latex-renderer .katex-display{margin:.5em 0}.latex-renderer .katex-error{color:#dc2626;background-color:#fef2f2;padding:4px;border-radius:4px;font-size:.9em}@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}@media (max-width: 1024px){div[style*=grid-template-columns][style*="1fr 300px"]{display:flex!important;flex-direction:column!important;grid-template-columns:none!important}.card:last-child{order:-1!important;margin-bottom:16px!important}}@media (max-width: 768px){.header-content{flex-direction:column!important;align-items:stretch!important;gap:12px!important;padding:12px 8px!important}.header-left{justify-content:center!important;text-align:center!important;flex-wrap:wrap!important}.header-actions{justify-content:center!important;flex-wrap:wrap!important;gap:8px!important}.title{font-size:18px!important;text-align:center!important;word-break:break-word!important}.badges{justify-content:center!important;flex-wrap:wrap!important;gap:6px!important}.badge{font-size:12px!important;padding:3px 6px!important}.main-content{padding:12px 8px!important}.card{padding:16px 12px!important;margin-bottom:12px!important}div[style*="display: grid"][style*=grid-template-columns][style*="1fr 300px"],div[style*="display: grid"][style*="grid-template-columns: 1fr"]{display:flex!important;flex-direction:column!important;gap:16px!important}div[style*="grid-template-columns: repeat(5, 1fr)"],div[style*="grid-template-columns: repeat(4, 1fr)"],div[style*="grid-template-columns: repeat(3, 1fr)"]{display:grid!important;flex-direction:initial!important}div[style*="display: flex"][style*="justify-content: space-between"][style*="align-items: flex-start"]{flex-direction:column!important;align-items:stretch!important;gap:12px!important}div[style*="display: flex"][style*="align-items: center"][style*="gap: 12px"]{flex-wrap:wrap!important;gap:8px!important}div[style*="font-size: 18px"][style*="font-weight: 500"]{font-size:16px!important;line-height:1.5!important}.form-input,.form-textarea,.form-select{font-size:16px!important;padding:12px!important}.form-textarea{min-height:120px!important}label[class*=answer-option]{padding:12px!important;font-size:14px!important;margin-bottom:8px!important;border-radius:6px!important}div[style*="display: flex"][style*="flex-direction: row"] label[class*=answer-option]{flex:1!important;min-width:auto!important;justify-content:center!important;margin-right:8px!important}div[style*="display: flex"][style*="flex-direction: row"] label[class*=answer-option]:last-child{margin-right:0!important}input[type=radio]{transform:scale(1.2)!important;margin-right:10px!important}div[style*="grid-template-columns: repeat(5, 1fr)"]{display:grid!important;grid-template-columns:repeat(4,1fr)!important;grid-auto-flow:row!important;gap:8px!important;justify-items:center!important;align-items:center!important}button[class*=question-nav-btn]{width:36px!important;height:36px!important;font-size:12px!important;min-height:36px!important;min-width:36px!important;display:flex!important;align-items:center!important;justify-content:center!important}div[class*=bottom-buttons]{flex-direction:column!important;gap:10px!important;margin-top:20px!important}div[class*=bottom-buttons] .btn{width:100%!important;justify-content:center!important;padding:12px 16px!important}div[style*="display: grid"][style*="grid-template-columns: repeat(auto-fit, minmax(150px, 1fr))"],div[style*="display: grid"][style*="grid-template-columns: repeat(auto-fit, minmax(250px, 1fr))"],div[style*="display: grid"][style*="grid-template-columns: repeat(2, 1fr)"]{grid-template-columns:1fr 1fr!important;gap:12px!important}div[class*=info-box][style*="padding: 20px"],div[class*=info-box][style*="padding: 16px"]{padding:12px!important}div[style*="font-size: 24px"][style*="font-weight: bold"]{font-size:20px!important}div[style*="position: fixed"][style*="background-color: rgba(0, 0, 0, 0.5)"] .card{margin:8px!important;width:calc(100% - 16px)!important;max-width:none!important}.card-header,h2[class*=card-header],h3[class*=card-header]{font-size:16px!important;margin-bottom:12px!important}div[style*="max-width: 800px"]{max-width:none!important}div[style*="padding: 32px"]{padding:16px!important}.btn{font-size:13px!important;padding:8px 12px!important;min-height:36px!important}.btn-large{padding:12px 16px!important;font-size:14px!important}div[style*="position: fixed"][style*="top: 20px"][style*="right: 20px"]{top:10px!important;right:10px!important;left:10px!important;width:auto!important;min-width:auto!important}img[style*="max-width: 100%"]{max-height:250px!important;object-fit:contain!important;width:100%!important}textarea[style*="min-height: 200px"]{min-height:150px!important}}@media (max-width: 480px){.title{font-size:16px!important}.badge{font-size:11px!important;padding:2px 4px!important}.btn{padding:8px 10px!important;font-size:12px!important;min-height:32px!important}.header-actions{flex-direction:column!important;width:100%!important}.header-actions .btn{width:100%!important}.main-content{padding:8px 4px!important}.card{padding:12px 8px!important}div[style*="font-size: 18px"][style*="font-weight: 500"]{font-size:14px!important}label[class*=answer-option]{padding:10px!important;font-size:13px!important}div[style*="grid-template-columns: repeat(5, 1fr)"],div[style*="grid-template-columns: repeat(4, 1fr)"]{display:grid!important;grid-template-columns:repeat(3,1fr)!important;grid-auto-flow:row!important;gap:6px!important;justify-items:center!important;align-items:center!important}button[class*=question-nav-btn]{width:32px!important;height:32px!important;font-size:11px!important;display:flex!important;align-items:center!important;justify-content:center!important}div[style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important;gap:8px!important}div[style*="font-size: 20px"][style*="font-weight: bold"],div[style*="font-size: 24px"][style*="font-weight: bold"]{font-size:16px!important}div[style*="position: fixed"] .card{margin:4px!important;width:calc(100% - 8px)!important}div[style*="grid-template-columns: repeat(auto-fit, minmax(250px, 1fr))"]{grid-template-columns:repeat(2,1fr)!important;gap:8px!important}img[style*="max-height: 250px"]{max-height:200px!important}.icon-btn{padding:6px!important;min-width:28px!important;min-height:28px!important}.points-input{width:50px!important;font-size:12px!important}.card-header,h2[class*=card-header],h3[class*=card-header]{font-size:14px!important;margin-bottom:10px!important}textarea[style*="min-height: 150px"],textarea[style*="min-height: 200px"]{min-height:120px!important;font-size:14px!important}.form-input,input[type=text]{font-size:14px!important;padding:10px!important}}@media (max-width: 768px) and (orientation: landscape){.main-content{padding:8px 12px!important}.card{padding:12px 16px!important}div[style*="grid-template-columns: repeat(3, 1fr)"]{display:grid!important;grid-template-columns:repeat(6,1fr)!important;grid-auto-flow:row!important;gap:6px!important;justify-items:center!important}div[style*="grid-template-columns: repeat(4, 1fr)"]{display:grid!important;grid-template-columns:repeat(8,1fr)!important;grid-auto-flow:row!important;gap:8px!important;justify-items:center!important}}@media (max-width: 768px){.badge:has(.lucide-timer){font-size:11px!important;font-weight:600!important}div[style*="display: flex"][style*="justify-content: space-between"]{flex-wrap:wrap!important;gap:8px!important}.latex-renderer{word-break:break-word!important;overflow-wrap:break-word!important}button[class*=icon-btn]{min-width:32px!important;min-height:32px!important;padding:6px!important}span[style*="font-size: 16px"],div[style*="font-size: 16px"]{font-size:14px!important;line-height:1.4!important}div[style*="width: 100%"][style*="height: 8px"]{height:6px!important;margin:4px 0!important}div[class*=bottom-buttons][style*="margin-top: 24px"]{margin-top:16px!important}button[style*="font-size: 18px"][style*="padding: 16px 32px"]{font-size:16px!important;padding:12px 24px!important;width:100%!important}}@supports (-webkit-touch-callout: none){.assignment-creator{min-height:-webkit-fill-available!important}@media (max-width: 768px){.main-content{padding-bottom:env(safe-area-inset-bottom,16px)!important}input[type=text],input[type=email],input[type=password],textarea,select{font-size:16px!important}}}@media (max-width: 768px){.btn,.icon-btn,button[class*=question-nav-btn],label[class*=answer-option],input[type=radio]{min-height:44px!important;min-width:44px!important}label[class*=answer-option]{margin-bottom:12px!important}label[class*=answer-option]:focus-within,label[class*=answer-option]:hover{transform:none!important;box-shadow:0 2px 4px #0000001a!important}}label[class*=answer-option]{display:flex!important;align-items:center!important;justify-content:flex-start!important;padding:12px 16px!important;margin-bottom:8px!important;border-radius:6px!important;cursor:pointer!important;transition:background-color .2s!important;width:100%!important;box-sizing:border-box!important;text-align:left!important}label[class*=answer-option] input[type=radio]{margin:0 12px 0 0!important;flex-shrink:0!important;width:16px!important;height:16px!important;transform:none!important;position:relative!important;order:1!important}label[class*=answer-option] span,label[class*=answer-option] div{flex:1!important;text-align:left!important;word-wrap:break-word!important;overflow-wrap:break-word!important;line-height:1.4!important;order:2!important}@media (max-width: 768px){label[class*=answer-option]{padding:12px!important;font-size:14px!important;margin-bottom:8px!important;display:flex!important;align-items:flex-start!important;justify-content:flex-start!important;text-align:left!important}label[class*=answer-option] input[type=radio]{margin:2px 10px 0 0!important;flex-shrink:0!important;width:18px!important;height:18px!important;transform:none!important;order:1!important}label[class*=answer-option] span,label[class*=answer-option] div{flex:1!important;text-align:left!important;word-wrap:break-word!important;line-height:1.4!important;order:2!important;margin:0!important}div[style*="display: flex"][style*="flex-direction: row"] label[class*=answer-option]{flex:1!important;margin-right:8px!important;justify-content:flex-start!important;text-align:left!important}div[style*="display: flex"][style*="flex-direction: row"] label[class*=answer-option]:last-child{margin-right:0!important}}@media (max-width: 480px){label[class*=answer-option]{padding:10px!important;font-size:13px!important}label[class*=answer-option] input[type=radio]{width:16px!important;height:16px!important;margin:1px 8px 0 0!important}}.quiz-question label[class*=answer-option]{display:flex!important;align-items:flex-start!important;text-align:left!important;justify-content:flex-start!important}.quiz-question label[class*=answer-option] input[type=radio]{order:1!important;margin-right:10px!important;margin-left:0!important;flex-shrink:0!important}.quiz-question label[class*=answer-option]>*:not(input){order:2!important;flex:1!important;text-align:left!important}.course-page{max-width:1200px;margin:0 auto;padding:20px}.breadcrumbs{font-size:14px;color:#666;margin-bottom:20px}.breadcrumb-link{color:#06c;cursor:pointer;text-decoration:none}.breadcrumb-link:hover{text-decoration:underline}.breadcrumb-separator{margin:0 8px;color:#999}.course-header{background:#fff;border-radius:8px;padding:30px;margin-bottom:30px;box-shadow:0 2px 4px #0000001a}.course-title-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}.course-info h1{margin:0 0 10px;color:#333;font-size:32px}.view-toggle-btn{padding:10px 20px;border:none;border-radius:20px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;gap:8px}.view-toggle-btn.teacher-view{background:#fff;border:2px solid #0066cc;color:#06c}.view-toggle-btn.teacher-view:hover,.view-toggle-btn.student-view{background:#06c;color:#fff}.view-toggle-btn.student-view:hover{background:#0052a3}.course-code{font-size:18px;color:#666;font-weight:600;margin-bottom:10px}.course-description{color:#555;margin-bottom:20px;font-size:16px}.course-meta{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-top:20px;padding-top:20px;border-top:1px solid #eee}.meta-item{display:flex;flex-direction:column}.meta-label{font-size:12px;color:#999;text-transform:uppercase;margin-bottom:4px}.status{display:inline-block;padding:4px 12px;border-radius:20px;font-size:14px;font-weight:500}.status.active{background:#e8f5e9;color:#2e7d32}.status.inactive{background:#ffebee;color:#c62828}.course-timeline{margin-top:30px}.course-timeline h2{margin-bottom:20px;color:#333}.section{background:#fff;border-radius:8px;margin-bottom:16px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.section-header{display:flex;align-items:center;padding:20px;cursor:pointer;transition:background-color .2s}.section-header:hover{background-color:#f5f5f5}.section-toggle{margin-right:12px;color:#666;font-size:12px}.section-header h3{flex:1;margin:0;color:#333;font-size:20px}.section-dates{font-size:14px;color:#666}.due-date,.submissions{display:flex;align-items:center}.badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;text-transform:uppercase}.badge-available{background:#e8f5e9;color:#2e7d32}.badge-upcoming{background:#fff3e0;color:#f57c00}.badge-urgent{background:#ffebee;color:#c62828}.badge-overdue{background:#f5f5f5;color:#616161}.badge-locked{background:#f3e5f5;color:#7b1fa2}.add-section-btn{width:100%;padding:16px;margin-top:20px;background:#06c;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.add-section-btn:hover{background:#0052a3}.loading{display:flex;justify-content:center;align-items:center;height:400px;font-size:18px;color:#666}.content-viewer-modal{position:fixed;inset:0;background:#000c;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.viewer-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.viewer-header h3{margin:0;color:#333;font-size:20px}.close-btn{background:none;border:none;font-size:24px;color:#666;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s}.close-btn:hover{background:#f5f5f5;color:#333}.viewer-body{flex:1;display:flex;justify-content:center;align-items:center;overflow:hidden;background:#f5f5f5}.pdf-viewer{width:100%;height:100%;border:none}.video-player{width:100%;max-width:900px;max-height:100%;background:#000}.course-tabs{display:flex;gap:8px;margin-bottom:30px;border-bottom:2px solid #eee}.tab{padding:12px 24px;background:none;border:none;border-bottom:2px solid transparent;color:#666;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s}.tab.active{color:#06c;border-bottom-color:#06c}.tab:hover{color:#06c;background:#f0f7ff}.students-tab{cursor:pointer!important}.students-tab:hover{background-color:#f0f7ff}.assignments-section{background:#fff;border-radius:8px;margin-bottom:24px;box-shadow:0 2px 4px #0000001a;overflow:hidden}.assignments-section .section-header{padding:20px;border-bottom:1px solid #eee;background-color:#f8f9fa}.assignments-section .section-header h3{margin:0;color:#333;font-size:18px;font-weight:600}.empty-assignments{padding:40px 20px;text-align:center}.empty-assignments .empty-icon{font-size:48px;margin-bottom:16px;opacity:.5}.empty-assignments h4{margin:0 0 8px;color:#333;font-size:18px}.empty-assignments p{margin:0 0 20px;color:#666;font-size:14px}.assignments-list{padding:0}.assignment-item{display:flex;align-items:flex-start;padding:16px 20px;border-bottom:1px solid #eee;cursor:pointer;transition:all .2s}.assignment-item:hover{background-color:#f8f9fa}.assignment-item:last-child{border-bottom:none}.assignment-icon{font-size:20px;margin-right:16px;margin-top:2px;flex-shrink:0}.assignment-details{flex:1;min-width:0}.assignment-details h4{margin:0 0 4px;color:#333;font-size:16px;font-weight:600}.assignment-description{margin:4px 0 8px;color:#666;font-size:14px;line-height:1.4}.assignment-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:#666}.assignment-points{font-weight:500;color:#059669}.assignment-type{text-transform:capitalize;background-color:#f3f4f6;padding:2px 8px;border-radius:12px;font-size:12px}.assignment-due-date{color:#dc2626;font-weight:500}.assignment-submissions{color:#666}.assignment-status{margin-left:16px;flex-shrink:0}.assignment-actions{display:flex;gap:8px;margin-left:16px;flex-shrink:0}.assignment-actions .btn-small{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;font-size:12px;border-radius:4px}.add-assignment-btn{width:100%;padding:12px 20px;margin:16px 0;border:2px dashed #ddd;background:transparent;color:#666;font-size:14px;border-radius:6px;cursor:pointer;transition:all .2s}.add-assignment-btn:hover{border-color:#06c;color:#06c;background:#f0f7ff}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.empty-content{text-align:center;padding:60px 20px;background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.empty-icon{font-size:64px;margin-bottom:20px;opacity:.5}.empty-content h3{margin:0 0 12px;color:#333;font-size:20px}.empty-content p{margin:0 0 24px;color:#666;font-size:16px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026;width:100%;max-width:500px;max-height:90vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#333}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #eee;background-color:#f8f9fa}.students-modal{max-width:800px;width:90vw;max-height:80vh;display:flex;flex-direction:column}.students-modal-body{flex:1;overflow-y:auto;padding:0}.students-actions-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;background-color:#f8f9fa}.students-info{display:flex;align-items:center;gap:8px}.students-count{font-weight:500;color:#333}.max-students{color:#666;font-size:14px}.students-list{padding:0}.student-item{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;transition:background-color .2s}.student-item:hover{background-color:#f8f9fa}.student-item:last-child{border-bottom:none}.student-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:#eee;color:#666;border-radius:50%;font-size:12px;font-weight:500;margin-right:12px;flex-shrink:0}.student-avatar{width:40px;height:40px;border-radius:50%;background-color:#06c;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;margin-right:16px;flex-shrink:0}.student-details{flex:1;min-width:0}.student-name{font-size:16px;font-weight:500;color:#333;margin:0 0 4px}.student-email{font-size:14px;color:#666;margin:0 0 4px}.enrollment-date{font-size:12px;color:#999;margin:0}.student-grade{font-size:12px;color:#059669;font-weight:500;margin:4px 0 0}.student-actions{display:flex;gap:8px;flex-shrink:0}.student-actions .btn-small{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:6px}.modal-empty{padding:40px 20px;text-align:center}.modal-empty .empty-icon{font-size:48px;margin-bottom:16px}.modal-empty h4{font-size:18px;font-weight:500;color:#333;margin:0 0 8px}.modal-empty p{color:#666;margin:0 0 20px}.role-update-modal{max-width:600px;width:90vw}.user-info-section{display:flex;align-items:center;gap:16px;padding:20px;background-color:#f8f9fa;border-radius:8px;margin-bottom:24px}.user-avatar-large{width:60px;height:60px;border-radius:50%;background-color:#06c;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;flex-shrink:0}.user-details h4{margin:0 0 4px;font-size:18px;font-weight:600;color:#333}.user-email{margin:0 0 8px;color:#666;font-size:14px}.current-role{margin:0;font-size:14px;color:#333}.role-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.role-student{background-color:#e3f2fd;color:#1976d2}.role-teacher{background-color:#e8f5e9;color:#388e3c}.role-admin{background-color:#fff3e0;color:#f57c00}.role-selection-section h5{margin:0 0 16px;font-size:16px;font-weight:600;color:#333}.role-options{display:flex;flex-direction:column;gap:12px}.role-option{display:flex;align-items:center;gap:16px;padding:16px;border:2px solid #eee;border-radius:8px;background-color:#fff;cursor:pointer;transition:all .2s;text-align:left;width:100%}.role-option:hover:not(:disabled){border-color:#06c;background-color:#f8fafc}.role-option:disabled{opacity:.5;cursor:not-allowed}.role-option.student:hover:not(:disabled){border-color:#1976d2}.role-option.teacher:hover:not(:disabled){border-color:#388e3c}.role-option.admin:hover:not(:disabled){border-color:#f57c00}.role-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:#f5f5f5;border-radius:8px;flex-shrink:0}.role-info{flex:1}.role-title{font-size:16px;font-weight:600;color:#333;margin-bottom:4px}.role-description{font-size:14px;color:#666;line-height:1.4}.add-student-modal{max-width:500px}.add-student-modal .modal-body{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:500;color:#333;margin-bottom:8px;font-size:14px}.form-input{width:100%;border:1px solid #ddd;border-radius:6px;padding:10px 12px;font-size:14px;background-color:#fff;color:#333;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:#06c;box-shadow:0 0 0 3px #0066cc1a}.form-input:disabled{background-color:#f5f5f5;color:#999;cursor:not-allowed}.error-message{background-color:#ffebee;color:#c62828;padding:12px;border-radius:6px;font-size:14px;margin:16px 0}.loading-message{display:flex;align-items:center;gap:12px;color:#666;font-size:14px;margin:16px 0}.spinner-small{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #0066cc;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn-primary{background-color:#06c;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:#0052a3}.btn-primary:disabled{background-color:#999;cursor:not-allowed}.btn-secondary{background-color:#f5f5f5;color:#333;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s}.btn-secondary:hover:not(:disabled){background-color:#eee}.btn-danger{background-color:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s}.btn-danger:hover:not(:disabled){background-color:#c82333}.btn-small{padding:6px 12px;font-size:12px}@media (max-width: 768px){.course-page{padding:10px}.course-header{padding:20px}.course-title-row{flex-direction:column;gap:16px}.view-toggle-btn{align-self:flex-start}.course-info h1{font-size:24px}.course-meta{grid-template-columns:1fr;gap:12px}.section-header{padding:16px}.section-header h3{font-size:18px}.content-item{flex-direction:column}.content-icon{margin-bottom:8px}.content-status{margin-left:0;margin-top:8px}.content-viewer{width:100%;height:85vh}.viewer-header{padding:16px}.viewer-header h3{font-size:18px}.role-update-modal{width:95vw}.user-info-section{flex-direction:column;text-align:center}.role-options{gap:8px}.loading-container{display:flex;justify-content:center;align-items:center;height:400px;flex-direction:column;gap:20px}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #0066cc;border-radius:50%;animation:spin 1s linear infinite}.error-container{background-color:#ffebee;border:1px solid #ffcdd2;border-radius:8px;padding:30px;margin:30px 0;text-align:center}.error-container h2{color:#c62828;margin:0 0 12px;font-size:24px}.error-container p{color:#666;margin:0 0 24px;font-size:16px}.error-actions{display:flex;gap:12px;justify-content:center}.error-actions button{padding:12px 24px;border:none;border-radius:6px;font-size:16px;font-weight:500;cursor:pointer;transition:background-color .2s}.error-actions .btn-primary{background-color:#06c;color:#fff}.error-actions .btn-primary:hover{background-color:#0052a3}.error-actions .btn-secondary{background-color:#f5f5f5;color:#333}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px}.filter-group{display:flex;flex-direction:column}.filter-label{font-weight:500;color:#374151;margin-bottom:8px;font-size:14px}.filter-select{width:100%;border:1px solid #d1d5db;border-radius:6px;padding:8px 12px;font-size:14px;background-color:#fff;color:#111827;transition:border-color .2s,box-shadow .2s}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.empty-state{text-align:center;padding:80px 20px}.empty-icon{font-size:80px;margin-bottom:20px}.empty-title{font-size:20px;font-weight:500;color:#111827;margin:0 0 10px}.empty-message{color:#6b7280;margin:0}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:24px}.course-card{background-color:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;border:1px solid #e5e7eb;transition:box-shadow .3s ease;overflow:hidden}.course-card:hover{box-shadow:0 4px 6px #0000001a}.course-content{padding:24px}.course-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px;gap:16px}.course-info{flex:1}.course-title{font-size:18px;font-weight:600;color:#111827;margin:0 0 4px;line-height:1.4}.course-code{font-size:14px;color:#6b7280;margin:0}.status-badge{display:inline-flex;align-items:center;padding:4px 8px;border-radius:9999px;font-size:12px;font-weight:500;text-transform:capitalize;white-space:nowrap}.status-active{background-color:#dcfce7;color:#166534}.status-completed{background-color:#dbeafe;color:#1e40af}.status-dropped{background-color:#fee2e2;color:#991b1b}.status-suspended{background-color:#fef3c7;color:#92400e}.course-description{color:#6b7280;font-size:14px;margin:0 0 16px;line-height:1.5;display:-webkit-box;-webkit-box-orient:vertical;overflow:hidden}.teacher-info{margin-bottom:16px}.teacher-text{font-size:14px;color:#6b7280;margin:0}.teacher-label{font-weight:500;color:#374151}.grade-info{margin-bottom:16px;padding:12px;background-color:#f9fafb;border-radius:6px}.grade-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:8px}.grade-text{font-size:14px;font-weight:500;color:#111827}.score-text{font-size:14px;color:#6b7280}.enrollment-date{font-size:12px;color:#9ca3af;margin-bottom:16px}.course-actions{display:flex;gap:8px;flex-wrap:wrap}.primary-btn{flex:1;background-color:#3b82f6;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s;min-width:120px}.primary-btn:hover{background-color:#2563eb}.secondary-btn{background-color:#f3f4f6;color:#374151;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s;white-space:nowrap}.secondary-btn:hover{background-color:#e5e7eb}.students-tab{cursor:pointer!important}.students-tab:hover{background-color:#f3f4f6}.students-modal{max-width:800px;width:90vw;max-height:80vh;display:flex;flex-direction:column}.students-modal-body{flex:1;overflow-y:auto;padding:0}.students-actions-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;background-color:#f9fafb}.students-info{display:flex;align-items:center;gap:8px}.students-count{font-weight:500;color:#111827}.max-students{color:#6b7280;font-size:14px}.students-list{padding:0}.student-item{display:flex;align-items:center;padding:16px 20px;border-bottom:1px solid #e5e7eb;transition:background-color .2s}.student-item:hover{background-color:#f9fafb}.student-item:last-child{border-bottom:none}.student-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;background-color:#e5e7eb;color:#6b7280;border-radius:50%;font-size:12px;font-weight:500;margin-right:12px;flex-shrink:0}.student-avatar{width:40px;height:40px;border-radius:50%;background-color:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px;margin-right:16px;flex-shrink:0}.student-details{flex:1;min-width:0}.student-name{font-size:16px;font-weight:500;color:#111827;margin:0 0 4px}.student-email{font-size:14px;color:#6b7280;margin:0 0 4px}.enrollment-date{font-size:12px;color:#9ca3af;margin:0}.student-grade{font-size:12px;color:#059669;font-weight:500;margin:4px 0 0}.student-actions{display:flex;gap:8px;flex-shrink:0}.student-actions .btn-small{width:32px;height:32px;padding:0;display:flex;align-items:center;justify-content:center;font-size:14px;border-radius:6px}.modal-empty{padding:40px 20px;text-align:center}.modal-empty .empty-icon{font-size:48px;margin-bottom:16px}.modal-empty h4{font-size:18px;font-weight:500;color:#111827;margin:0 0 8px}.modal-empty p{color:#6b7280;margin:0 0 20px}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background-color:#fff;border-radius:8px;box-shadow:0 10px 25px #00000026;width:100%;max-width:500px;max-height:90vh;overflow:hidden}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.close-btn{background:none;border:none;font-size:18px;cursor:pointer;color:#6b7280;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .2s}.close-btn:hover{background-color:#f3f4f6;color:#111827}.modal-body{padding:20px}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid #e5e7eb;background-color:#f9fafb}.role-update-modal{max-width:600px;width:90vw}.user-info-section{display:flex;align-items:center;gap:16px;padding:20px;background-color:#f9fafb;border-radius:8px;margin-bottom:24px}.user-avatar-large{width:60px;height:60px;border-radius:50%;background-color:#3b82f6;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:20px;flex-shrink:0}.user-details h4{margin:0 0 4px;font-size:18px;font-weight:600;color:#111827}.user-email{margin:0 0 8px;color:#6b7280;font-size:14px}.current-role{margin:0;font-size:14px;color:#374151}.role-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:500;text-transform:capitalize}.role-student{background-color:#dbeafe;color:#1e40af}.role-teacher{background-color:#dcfce7;color:#166534}.role-admin{background-color:#fef3c7;color:#92400e}.role-selection-section h5{margin:0 0 16px;font-size:16px;font-weight:600;color:#111827}.role-options{display:flex;flex-direction:column;gap:12px}.role-option{display:flex;align-items:center;gap:16px;padding:16px;border:2px solid #e5e7eb;border-radius:8px;background-color:#fff;cursor:pointer;transition:all .2s;text-align:left;width:100%}.role-option:hover:not(:disabled){border-color:#3b82f6;background-color:#f8fafc}.role-option:disabled{opacity:.5;cursor:not-allowed}.role-option.student:hover:not(:disabled){border-color:#1e40af}.role-option.teacher:hover:not(:disabled){border-color:#166534}.role-option.admin:hover:not(:disabled){border-color:#92400e}.role-icon{font-size:24px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:#f3f4f6;border-radius:8px;flex-shrink:0}.role-info{flex:1}.role-title{font-size:16px;font-weight:600;color:#111827;margin-bottom:4px}.role-description{font-size:14px;color:#6b7280;line-height:1.4}.add-student-modal{max-width:500px}.add-student-modal .modal-body{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:500;color:#374151;margin-bottom:8px;font-size:14px}.form-input{width:100%;border:1px solid #d1d5db;border-radius:6px;padding:10px 12px;font-size:14px;background-color:#fff;color:#111827;transition:border-color .2s,box-shadow .2s}.form-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.error-message{background-color:#fee2e2;color:#dc2626;padding:12px;border-radius:6px;font-size:14px;margin:16px 0}.loading-message{display:flex;align-items:center;gap:12px;color:#6b7280;font-size:14px;margin:16px 0}.spinner-small{width:16px;height:16px;border:2px solid #f3f3f3;border-top:2px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}.btn-primary{background-color:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:disabled{background-color:#9ca3af;cursor:not-allowed}.btn-secondary{background-color:#f3f4f6;color:#374151;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s}.btn-secondary:hover:not(:disabled){background-color:#e5e7eb}.btn-danger{background-color:#ef4444;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:background-color .2s}.btn-danger:hover:not(:disabled){background-color:#dc2626}.btn-small{padding:6px 12px;font-size:12px}.modal-overlay{padding:10px}.students-modal{width:95vw;max-height:85vh}.students-actions-bar,.student-item{flex-direction:column;align-items:flex-start;gap:12px;padding:16px}.student-number{align-self:flex-start}.student-actions{width:100%;justify-content:flex-end}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}.student-courses-container{padding:16px}.page-title{font-size:24px}.header{flex-direction:column;align-items:flex-start}.courses-grid{grid-template-columns:1fr;gap:16px}.course-header{flex-direction:column;align-items:flex-start;gap:8px}.course-actions{flex-direction:column}.primary-btn,.secondary-btn{width:100%}.filters-grid{grid-template-columns:1fr;gap:16px}.grade-content{flex-direction:column;align-items:flex-start}@media (max-width: 480px){.course-content{padding:16px}.page-title{font-size:20px}.course-title{font-size:16px}}}
