*{box-sizing:border-box}html{overflow-y:scroll}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{font-family:inherit;cursor:pointer}input,textarea,select{font-family:inherit}.login-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#e3f2fd,#c3d9eb 25%,#c3b5ce 75%,#e1bee7);padding:40px 20px;position:relative}.login-header{text-align:center;margin-bottom:30px}.logo{display:flex;align-items:center;justify-content:center;gap:12px}.logo-image{width:80px;height:80px;object-fit:contain;flex-shrink:0}.logo-text{font-size:28px;font-weight:600;color:#4a148c}.login-tabs{display:flex;gap:0;margin-bottom:20px;background:#fff;border-radius:50px;padding:6px;box-shadow:0 2px 4px #0000001a;width:fit-content;max-width:380px;align-self:center}.tab{flex:1;padding:12px 28px;border:none;background:transparent;cursor:pointer;font-size:16px;color:#666;border-radius:50px;transition:all .3s;font-weight:500;min-width:120px}.tab.active{background:#000;color:#fff;font-weight:600}.tab:not(.active):hover{background:#f5f5f5}.login-card{background:#fff;border-radius:16px;padding:40px;width:100%;max-width:450px;box-shadow:0 4px 20px #0000001a}.login-form{display:flex;flex-direction:column;gap:20px}.login-form h2{margin:0 0 8px;font-size:28px;font-weight:700;color:#333}.subtitle{margin:0 0 10px;color:#666;font-size:14px;font-weight:400}.form-field{display:flex;flex-direction:column;gap:8px}.form-field label{font-size:14px;font-weight:500;color:#333}.field-hint{font-size:12px;color:#666;margin-top:-4px;font-style:italic}.login-form input[type=text],.login-form input[type=email],.login-form input[type=password]{padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:16px;background:#f9f9f9;transition:all .3s;color:#333}.login-form input[type=text]:focus,.login-form input[type=email]:focus,.login-form input[type=password]:focus{outline:none;border-color:#9c27b0;background:#fff}.radio-group{display:flex;flex-direction:column;gap:12px;margin-top:8px}.radio-label{font-size:14px;font-weight:500;color:#333;margin-bottom:4px}.radio-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.radio-list li{margin:0}.radio-list li label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400;font-size:14px;color:#333;position:relative;padding-left:28px}.radio-list li input[type=radio]{position:absolute;opacity:0;cursor:pointer;width:0;height:0}.radio-custom{position:absolute;left:0;top:50%;transform:translateY(-50%);width:18px;height:18px;border-radius:50%;border:2px solid #999;background:#fff;transition:all .2s}.radio-list li input[type=radio]:checked~.radio-custom{background:#000;border-color:#000}.radio-list li input[type=radio]:checked~.radio-custom:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:6px;height:6px;border-radius:50%;background:#fff}.error-message{background:#ffebee;color:#c62828;padding:12px 16px;border-radius:8px;font-size:14px;border:1px solid #ef5350}.submit-button{background:#1976d2;color:#fff;padding:14px 24px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s;margin-top:8px;width:100%}.submit-button:hover{background:#1565c0;transform:translateY(-1px);box-shadow:0 4px 8px #1976d24d}.submit-button:active{transform:translateY(0);box-shadow:0 2px 4px #0003}.forgot-password-text{text-align:center;font-size:13px;color:#888;margin:0}.app-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff;border-bottom:1px solid #e0e0e0;box-shadow:0 2px 4px #0000000d}.header-left{display:flex;align-items:center}.logo{display:flex;align-items:center;gap:12px}.logo-image{width:60px;height:60px;object-fit:contain}.logo-text{font-size:18px;font-weight:600;color:#333}.header-title{font-size:24px;font-weight:600;color:#333;margin:0}.header-right{display:flex;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:8px}.user-icon{font-size:20px;color:#666}.user-name{font-size:14px;color:#666;font-weight:500}.logout-button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px;color:#333;transition:all .3s}.logout-button:hover{background:#e0e0e0}.icon-arrow{font-size:16px}.student-main{min-height:100vh;background:#f5f5f5}.student-content{max-width:1200px;margin:0 auto;padding:24px}.term-title{font-size:32px;font-weight:700;color:#4a148c;margin:0 0 16px;text-align:left}.student-overall-grade{margin:-8px 0 20px;font-size:16px;font-weight:600;color:#333}.student-nav{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 24px;padding-bottom:12px;border-bottom:1px solid #e0e0e0;align-items:center}.student-nav button{padding:10px 20px;margin:0;background:transparent;border:none;border-radius:20px;cursor:pointer;font-size:14px;font-weight:500;font-family:inherit;color:#666;transition:background .2s ease,color .2s ease}.student-nav button:hover{background:#f0f0f0;color:#333}.student-nav button.active{background:#e0e0e0;color:#333}.announcements-section{margin-bottom:24px;width:100%}.bottom-grid{display:flex!important;flex-direction:row!important;gap:24px;margin-bottom:32px;align-items:stretch;width:100%}.bottom-grid>.card{--student-pair-card-height: 240px;flex:1 1 0;min-width:0;height:var(--student-pair-card-height);min-height:var(--student-pair-card-height);max-height:var(--student-pair-card-height);display:flex;flex-direction:column;padding:24px 26px;align-items:stretch;overflow:hidden}.card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 4px #0000001a}.announcements-card{display:flex;flex-direction:column}.announcements-card .card-title{flex-shrink:0}.announcements-list{display:flex;flex-direction:column;gap:0}.announcements-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px 16px;margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.announcement-item{display:flex;gap:16px;padding:16px 0;border-bottom:1px solid #e0e0e0}.announcement-item:last-child{border-bottom:none}.announcement-indicator{width:4px;background:#9c27b0;border-radius:2px;flex-shrink:0}.announcement-content{flex:1}.announcement-title{font-size:16px;font-weight:600;color:#333;margin:0 0 8px}.announcement-description{font-size:14px;color:#666;margin:0 0 8px;line-height:1.5;white-space:pre-wrap;word-break:break-word}.announcement-description.truncated{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.read-more-btn{background:none;border:none;padding:0;margin:0 0 6px;font-size:13px;font-weight:500;color:#9c27b0;cursor:pointer}.read-more-btn:hover{text-decoration:underline}.announcement-meta{display:flex;align-items:center;gap:12px;font-size:12px;color:#999;margin-top:4px}.announcement-teacher{font-weight:500;color:#666}.announcement-date{color:#999}.zoom-card{display:flex;flex-direction:column;gap:16px;justify-content:flex-start;flex-shrink:0;min-height:0}.zoom-card .zoom-button,.zoom-card .zoom-unavailable{flex-shrink:0}.zoom-card .zoom-unavailable{overflow-y:auto;max-height:100%}.zoom-card .card-title{margin-bottom:0}.zoom-unavailable{font-size:14px;color:#999;font-style:italic;text-align:center;margin:0;padding:12px;background:#f5f5f5;border-radius:8px}.zoom-button{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 24px;background:#fff;color:#333;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .3s}.zoom-button:hover{background:#f5f5f5;border-color:#9c27b0}.icon-arrow{font-size:18px}.assignments-card{display:flex;flex-direction:column;gap:10px;overflow:hidden;flex-shrink:0;min-height:0}.assignments-card .card-title{margin-bottom:0;flex-shrink:0}.assignment-count{font-size:14px;color:#666;margin:0;flex-shrink:0}.assignments-card .assignment-count:last-child{margin-bottom:0}.assignments-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;overflow-x:hidden;flex:1 1 auto;min-height:0;padding-right:8px;scrollbar-width:thin;scrollbar-color:#d0d0d0 #f5f5f5}.assignments-list::-webkit-scrollbar{-webkit-appearance:none;width:6px;display:block}.assignments-list::-webkit-scrollbar-track{background:#f5f5f5;border-radius:3px;display:block}.assignments-list::-webkit-scrollbar-thumb{background:#d0d0d0;border-radius:3px;display:block}.assignments-list::-webkit-scrollbar-thumb:hover{background:#b0b0b0}.assignment-item{padding:12px;background:#f9f9f9;border-radius:8px;transition:all .3s;flex-shrink:0}.assignment-item.clickable{cursor:pointer}.assignment-item.clickable:hover{background:#f0f0f0;transform:translateY(-2px);box-shadow:0 2px 8px #0000001a}.assignment-name{font-size:15px;font-weight:600;color:#333;margin:0 0 6px}.assignment-description{font-size:13px;color:#666;margin:0 0 8px}.assignment-due{display:flex;align-items:center;gap:6px;font-size:12px;color:#999}.icon-clock{font-size:14px}.modules-section{margin:48px 0;padding:32px 0;border-top:2px solid #e0e0e0;border-bottom:2px solid #e0e0e0}.section-title{font-size:28px;font-weight:700;color:#333;margin:0 0 24px}.module-card{display:flex;align-items:center;gap:20px;background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 4px #0000001a}.module-status-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.status-checkmark{width:40px;height:40px;border-radius:50%;background:#4caf50;color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.status-number{width:40px;height:40px;border-radius:50%;background:#9c27b0;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.status-lock{font-size:24px;color:#999}.module-info{flex:1}.module-name{font-size:18px;font-weight:600;color:#333;margin:0 0 8px}.module-description{font-size:14px;color:#666;margin:0 0 12px}.module-due{display:flex;align-items:center;gap:6px;font-size:12px;color:#999}.module-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.module-grade{font-size:14px;font-weight:500;color:#4caf50;margin-right:8px}.btn-completed{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer}.btn-review{padding:8px 16px;background:#fff;color:#333;border:1px solid #ddd;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-review:hover{background:#f5f5f5}.btn-start-module{padding:10px 20px;background:#000;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s;position:relative;z-index:1}.btn-start-module:hover{background:#333}.btn-start-module:active{transform:scale(.98)}.btn-locked{padding:10px 20px;background:#e0e0e0;color:#999;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:not-allowed}.surveys-section{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-bottom:0}.survey-card{text-align:center}.ceu-section{margin-top:32px;padding-top:0;border-top:none;width:100%}.ceu-consolidated-card{padding:32px}.ceu-consolidated-card .section-title{margin-bottom:24px;font-size:24px;font-weight:600;color:#333;text-align:center}.ceu-links-list{display:flex;flex-direction:column;gap:20px}.ceu-link-item{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#f9f9f9;border-radius:8px;border:1px solid #e0e0e0;transition:all .2s}.ceu-link-item:hover{background:#f5f5f5;border-color:#333}.ceu-link-title{font-size:16px;font-weight:500;color:#333;margin:0}.ceu-link-button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;background:#333;color:#fff;text-decoration:none;border-radius:6px;font-size:14px;font-weight:500;transition:all .2s;white-space:nowrap}.ceu-link-button:hover{background:#000;transform:translateY(-1px);box-shadow:0 2px 6px #0000004d}.ceu-link-button .icon-link{font-size:14px}@media(max-width:768px){.ceu-link-item{flex-direction:column;align-items:flex-start;gap:12px}.ceu-link-button{width:100%;justify-content:center}}.btn-survey{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s}.btn-survey:hover{background:#7b1fa2}.btn-survey.disabled{background:#e0e0e0;color:#999;cursor:not-allowed}.icon-link,.icon-lock{font-size:16px}@media(max-width:768px){.bottom-grid{flex-direction:column}.bottom-grid>.card{height:auto;min-height:200px;max-height:none}.assignments-list{max-height:260px}.surveys-section{grid-template-columns:1fr}.module-card{flex-direction:column;align-items:flex-start}.module-actions{width:100%;justify-content:flex-start}}.resources-nav-section{margin-top:32px}.card.resources-nav-card{display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s;background:#f3e5f5;border:1px solid #e1bee7}.card.resources-nav-card:hover{box-shadow:0 4px 12px #9c27b026;transform:translateY(-1px);background:#edd5f0}.resources-nav-icon{font-size:28px;flex-shrink:0}.resources-nav-description{font-size:13px;color:#888;margin:4px 0 0}.resources-nav-arrow{font-size:20px;color:#999;margin-left:auto;flex-shrink:0}.student-hw{min-height:100vh;background:#f5f5f5}.hw-content{max-width:900px;margin:0 auto;padding:24px}.hw-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px}.module-name-header{flex:1;text-align:center;font-size:20px;font-weight:600;color:#1976d2;margin:0}.questions-container{display:flex;flex-direction:column;gap:24px;margin-bottom:32px}.question-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 4px #0000001a}.question-number{font-size:18px;font-weight:600;color:#333;margin:0 0 12px}.question-text{font-size:16px;color:#333;margin:0 0 20px;line-height:1.6}.response-type-selection{display:flex;gap:0;margin-bottom:20px;background:#f5f5f5;border-radius:8px;padding:4px}.response-type-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:8px 12px;background:transparent;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .3s}.response-type-btn.active{background:#e8e8e8;color:#333;font-weight:500}.response-type-btn:not(.active){color:#999;background:transparent}.response-type-btn:hover:not(.active){background:#f0f0f0}.icon-doc,.icon-mic{font-size:16px}.response-textarea{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:150px;background:#fafafa}.response-textarea:focus{outline:none;border-color:#9c27b0;background:#fff}.response-textarea::placeholder{color:#999}.audio-recording{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px}.recording-controls{display:flex;flex-direction:column;align-items:center;gap:16px;width:100%}.recording-indicator{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#ffebee;border-radius:8px;border:2px solid #ef5350}.recording-dot{width:12px;height:12px;background:#ef5350;border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.recording-time{font-weight:600;color:#c62828;font-size:16px}.stop-button{padding:12px 24px;background:#ef5350;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:all .3s}.stop-button:hover{background:#c62828}.audio-playback{display:flex;flex-direction:column;gap:12px;width:100%;padding:16px;background:#f5f5f5;border-radius:8px;border:1px solid #ddd}.audio-status{font-size:14px;color:#666;margin:0;text-align:center}.audio-controls{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.play-button{padding:10px 20px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:all .3s}.play-button:hover{background:#388e3c}.re-record-button{padding:10px 20px;background:#ff9800;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:all .3s}.re-record-button:hover{background:#f57c00}.record-button{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;background:#424242;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:all .3s}.record-button:hover{background:#616161}.submit-section{display:flex;justify-content:center;padding-top:24px;margin-top:32px}.submission-complete-notice{padding:16px 24px;background:#e8f5e9;border:2px solid #4caf50;border-radius:8px;text-align:center}.submission-complete-notice p{margin:0;color:#2e7d32;font-weight:500;font-size:16px}.submit-button{padding:10px 24px;background:#81c784;color:#2e7d32;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px;transition:all .3s}.submit-button:hover{background:#66bb6a;color:#1b5e20}.submit-button:active{transform:scale(.98)}.submit-button:disabled{opacity:.6;cursor:not-allowed}.review-notice{background:#e3f2fd;border:1px solid #90caf9;border-radius:8px;padding:12px 16px;margin-bottom:24px;color:#1565c0;font-size:14px}.submission-grade{margin-top:16px;padding:16px;background:#e8f5e9;border-radius:8px;color:#2e7d32;font-size:14px}.grade-score{margin-bottom:12px}.teacher-comment{margin-top:12px;padding-top:12px;border-top:1px solid #a5d6a7}.teacher-comment strong{display:block;margin-bottom:8px;color:#1b5e20;font-size:13px}.comment-text{margin:0;padding:10px;background:#fff;border-radius:6px;color:#333;font-size:14px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word}.question-card.has-submission{border:2px solid #4caf50}.record-button:disabled{opacity:.6;cursor:not-allowed}.response-type-btn:disabled{opacity:.6;cursor:not-allowed}.mcq-options{margin-top:16px;display:flex;flex-direction:column;gap:12px}.mcq-option{display:flex;align-items:center;padding:12px 16px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s}.mcq-option:hover{border-color:#9c27b0;background:#f5f5f5}.mcq-option input[type=radio]{margin-right:12px;width:20px;height:20px;cursor:pointer;accent-color:#9c27b0}.mcq-option input[type=radio]:checked+.option-text{color:#9c27b0;font-weight:500}.mcq-option:has(input[type=radio]:checked){border-color:#9c27b0;background:#f3e5f5}.mcq-option input[type=radio]:disabled{cursor:not-allowed}.mcq-option:has(input[type=radio]:disabled){opacity:.6;cursor:not-allowed}.option-text{flex:1;font-size:15px;color:#333}.link-input-section{display:flex;flex-direction:column;gap:8px}.link-hint{margin:0;font-size:13px;color:#666}.link-input{width:100%;padding:12px 16px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;background:#fafafa}.link-input:focus{outline:none;border-color:#9c27b0;background:#fff}.link-input::placeholder{color:#999}.link-preview{font-size:13px;color:#1976d2;word-break:break-all;text-decoration:none}.link-preview:hover{text-decoration:underline}.link-review-display{padding:12px 16px;background:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.submitted-link{color:#1976d2;font-size:14px;word-break:break-all;text-decoration:none}.submitted-link:hover{text-decoration:underline}.correct-answer{margin-top:12px;padding:12px;background:#e8f5e9;border-left:4px solid #4caf50;border-radius:4px;color:#2e7d32;font-size:14px}.field-assignment-hw{margin-top:12px;padding:16px;background:#fafafa;border-radius:8px;border:1px solid #e8e8e8}.field-assignment-intro{margin:0 0 16px;font-size:14px;color:#444;line-height:1.5}.field-assignment-file-label{display:inline-block;cursor:pointer}.field-assignment-file-input{display:none}.field-assignment-file-btn{display:inline-block;padding:10px 20px;background:#9c27b0;color:#fff;border-radius:8px;font-weight:500;font-size:14px}.field-assignment-file-btn:hover{background:#7b1fa2}.field-assignment-file-name{margin:12px 0 0;font-size:14px;color:#666}.field-assignment-or{margin:16px 0;text-align:center;font-size:13px;color:#888;font-weight:500}.field-assignment-youtube-label{display:block;margin-top:20px;margin-bottom:6px;font-size:14px;font-weight:600;color:#333}.field-assignment-youtube-input{width:100%;max-width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid #ccc;border-radius:8px;font-size:14px}.field-assignment-review{padding:12px 0 0}.field-assignment-review-title{margin:0 0 8px;font-size:15px;font-weight:600;color:#333}.field-assignment-review-line{margin:8px 0;font-size:14px;color:#333;word-break:break-word}.field-assignment-review-line a{color:#1976d2}.student-module-video{min-height:100vh;background:#f5f5f5}.video-content{max-width:1200px;margin:0 auto;padding:24px}.video-header{text-align:center;margin-bottom:32px}.video-header h1{font-size:32px;font-weight:600;color:#333;margin:0 0 12px}.module-description{font-size:16px;color:#666;max-width:800px;margin:0 auto}.video-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px}.video-wrapper{position:relative;width:100%;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:8px;background:#000}.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%}.no-video-message{text-align:center;padding:48px 24px}.no-video-message h2{font-size:24px;color:#333;margin:0 0 16px}.no-video-message p{font-size:16px;color:#666;margin:0 0 32px}.video-actions{display:flex;justify-content:center;margin-top:32px}.btn-next{padding:14px 32px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;gap:8px}.btn-next:hover{background:#7b1fa2;transform:translateY(-2px);box-shadow:0 4px 12px #9c27b04d}.btn-next:active{transform:translateY(0)}@media(max-width:768px){.video-content{padding:16px}.back-button{width:100%;justify-content:center}.video-header h1{font-size:24px}.video-container{padding:16px}.btn-next{width:100%;justify-content:center}}.field-assignment{min-height:100vh;background:#f5f5f5}.field-content{max-width:700px;margin:0 auto;padding:24px}.field-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.back-button{background:transparent;border:none;color:#9c27b0;cursor:pointer;font-size:14px;font-weight:500;padding:8px 0;display:flex;align-items:center;gap:4px;transition:all .3s;margin-bottom:16px}.back-button:hover{opacity:.8}.back-arrow{font-size:18px;line-height:1;color:#9c27b0}.due-date{font-size:14px;color:#666}.assignment-title{font-size:32px;font-weight:600;color:#333;margin:0 0 32px}.prompt-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 4px #0000001a}.prompt-label{font-size:16px;font-weight:600;color:#333;margin:0 0 12px}.prompt-text{font-size:16px;color:#333;line-height:1.6;margin:0}.file-upload-section{background:#fff;border-radius:12px;padding:24px;margin-bottom:24px;box-shadow:0 2px 4px #0000001a}.file-input{display:none}.file-upload-label{display:block;cursor:pointer}.file-upload-button{display:inline-block;padding:12px 24px;background:#9c27b0;color:#fff;border-radius:8px;font-weight:500;transition:background .3s}.file-upload-button:hover{background:#7b1fa2}.file-name{margin-top:12px;font-size:14px;color:#666}.submit-section{display:flex;justify-content:flex-end}.submit-button{padding:14px 32px;background:#4caf50;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;transition:background .3s}.submit-button:hover{background:#45a049}.field-assignment-page-hint{margin:0 0 16px;font-size:14px;color:#444;line-height:1.5}.field-assignment-or-page{margin:16px 0;text-align:center;font-size:13px;color:#888;font-weight:500}.field-assignment-youtube-label-page{display:block;margin-top:20px;margin-bottom:8px;font-size:14px;font-weight:600;color:#333}.field-assignment-youtube-input-page{width:100%;box-sizing:border-box;padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;margin-bottom:8px}.student-resources-page{min-height:100vh;background:#f5f5f5}.student-resources-content{max-width:1000px;margin:0 auto;padding:32px 24px}.back-button{padding:8px 16px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;color:#666;cursor:pointer;transition:all .2s;margin-bottom:24px}.back-button:hover{background:#f5f5f5;color:#333}.resources-page-title{font-size:26px;font-weight:700;color:#333;margin:0 0 28px}.no-resources-message{background:#fff;border-radius:12px;padding:40px;text-align:center;color:#888;font-size:15px;box-shadow:0 1px 4px #0000000f}.resources-grid{display:flex;flex-direction:column;gap:20px}.resource-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 4px #0000000f;border:1px solid #e8e8e8}.resource-card-title{font-size:18px;font-weight:600;color:#333;margin:0 0 8px}.resource-card-description{font-size:14px;color:#666;margin:0 0 16px;line-height:1.6}.resource-card-links{display:flex;flex-direction:column;gap:8px}.resource-card-link{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#e8eaf6;color:#1a237e;border-radius:8px;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s}.resource-card-link:hover{background:#c5cae9}.link-icon{font-size:14px}@media(max-width:600px){.student-resources-content{padding:20px 16px}.resources-page-title{font-size:22px}}.teacher-main{min-height:100vh;background:#f5f5f5}.teacher-content{max-width:1200px;margin:0 auto;padding:24px}.overview-content{display:flex;flex-direction:column;gap:24px}.card{background:#fff;border-radius:12px;padding:24px;border:1px solid #e0e0e0}.card-title{font-size:18px;font-weight:600;color:#333;margin:0 0 20px}.module-completion-card{margin-bottom:24px}.module-progress-list{display:flex;flex-direction:column;gap:16px}.module-progress-item{display:flex;flex-direction:column;gap:8px}.module-progress-header{display:flex;justify-content:space-between;align-items:center}.module-name{font-weight:500;color:#333}.progress-percentage{font-weight:600;color:#9c27b0}.progress-bar-container{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-bar{height:100%;background:#9c27b0;transition:width .3s}.students-card{margin-bottom:24px}.students-list{display:flex;flex-direction:column;gap:16px}.student-item{display:flex;align-items:center;gap:16px;padding:16px;background:#f9f9f9;border-radius:8px}.student-info{flex:1}.student-name{font-size:16px;font-weight:600;color:#333;margin:0 0 4px}.student-email{font-size:14px;color:#666;margin:0}.student-stats{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.grade{font-size:14px;font-weight:500;color:#333}.grade-weighting-note{font-weight:400;font-size:12px;color:#666}.status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status.no-overdue{background:#e8f5e9;color:#2e7d32}.status.overdue{background:#ffebee;color:#c62828}.teachers-card{margin-bottom:24px}.teachers-list{display:flex;flex-direction:column;gap:16px}.teacher-item{display:flex;align-items:center;gap:16px;padding:16px;background:#f9f9f9;border-radius:8px}.teacher-info{flex:1;min-width:0}.teacher-name{font-size:16px;font-weight:600;color:#333;margin:0 0 4px}.teacher-email{font-size:14px;color:#666;margin:0}.grading-tab-content{padding:24px;background:#fff;border-radius:12px;border:1px solid #e0e0e0}.reset-password-btn{padding:6px 14px;background:transparent;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:13px;color:#666;transition:all .2s;flex-shrink:0}.reset-password-btn:hover{background:#fff3e0;border-color:#ff9800;color:#e65100}.teacher-modules{min-height:100vh;background:#f5f5f5}.modules-content{max-width:1200px;margin:0 auto;padding:24px}.modules-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modules-header h1{font-size:24px;font-weight:600;color:#333;margin:0}.modules-list{display:flex;flex-direction:column;gap:16px}.module-card{background:#fff;border-radius:12px;padding:24px;border:1px solid #e0e0e0;width:100%;box-sizing:border-box;display:flex;flex-direction:column;align-items:flex-start;gap:12px;text-align:left;box-shadow:0 2px 8px #0000000f}.module-card--draft{border-left:4px solid #9c27b0}.module-card--posted{border-left:4px solid #66bb6a}.module-top-row{display:flex;align-items:center;gap:12px;width:100%;justify-content:flex-start}.module-order-badge{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;background:#9c27b0;color:#fff;border-radius:8px;font-weight:600;font-size:14px;flex-shrink:0}.module-title{font-size:18px;font-weight:600;color:#333;margin:0;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis}.posted-badge{padding:4px 10px;background:#4caf50;color:#fff;border-radius:12px;font-size:12px;font-weight:600;white-space:nowrap;flex-shrink:0}.module-description{font-size:14px;color:#666;margin:0;line-height:1.5}.module-meta{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:6px;font-size:13px;color:#888;width:100%}.meta-separator{color:#ccc;-webkit-user-select:none;user-select:none}.due-date{color:#888}.questions-toggle{display:inline-flex;align-items:center;gap:5px;background:transparent;border:none;cursor:pointer;font-size:13px;color:#9c27b0;padding:0;font-weight:500}.questions-toggle:hover{text-decoration:underline}.toggle-arrow{font-size:10px;transition:transform .2s}.toggle-arrow.expanded{transform:rotate(180deg)}.questions-list{padding-top:12px;border-top:1px solid #f0f0f0;display:flex;flex-direction:column;gap:8px;width:100%}.module-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:flex-start;padding-top:12px;border-top:1px solid #f0f0f0;min-height:0;width:100%}.module-posted-footer{width:100%;padding:10px 12px;background:#f1f8f4;border-radius:8px;border:1px solid #c8e6c9}.posted-module-hint{font-size:13px;color:#2e7d32;line-height:1.4}.btn-edit{padding:7px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:6px;cursor:pointer;font-size:13px;color:#333;transition:all .2s}.btn-edit:hover{background:#eee;border-color:#ccc}.btn-post{padding:7px 16px;background:#9c27b0;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.btn-post:hover{background:#7b1fa2}.btn-post:disabled{opacity:.45;cursor:not-allowed;background:#ccc}.btn-post:disabled:hover{background:#ccc}.btn-delete-module{padding:7px 16px;margin-left:auto;background:#fff;border:1px solid #e57373;color:#c62828;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s}.btn-delete-module:hover{color:#fff;background:#c62828;border-color:#c62828}.question-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fafafa;border-radius:6px;font-size:14px}.question-number{font-weight:600;color:#9c27b0;min-width:24px}.question-text{flex:1;font-size:14px;color:#333}.question-type{padding:4px 8px;background:#e3f2fd;color:#1976d2;border-radius:4px;font-size:12px;font-weight:500}.no-course-message,.no-modules-message{padding:48px;text-align:center;background:#fff;border-radius:12px;border:1px solid #e0e0e0}.no-course-message p,.no-modules-message p{font-size:16px;color:#666;margin:0}.post-confirm-modal{background:#fff;border-radius:12px;padding:32px;width:90%;max-width:500px;box-shadow:0 4px 20px #00000026}.post-confirm-modal h2{margin:0 0 24px;font-size:24px;font-weight:600;color:#333;display:flex;align-items:center;gap:8px}.post-confirm-message{margin-bottom:24px}.post-confirm-message .warning-text{font-size:16px;color:#d32f2f;margin:0 0 16px;line-height:1.5}.post-confirm-message .confirm-question{font-size:16px;color:#333;margin:0;line-height:1.5}.post-confirm-message strong{font-weight:600}.modal-actions .btn-cancel{padding:10px 20px;background:#f5f5f5;color:#333;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.modal-actions .btn-cancel:hover{background:#e0e0e0}.modal-actions .btn-confirm{padding:10px 20px;background:#ffc107;color:#333;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.modal-actions .btn-confirm:hover{background:#ffb300}.modal-actions .btn-confirm-delete{padding:10px 20px;background:#c62828;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.modal-actions .btn-confirm-delete:hover{background:#b71c1c}.delete-module-modal .post-confirm-message .warning-text{color:#333}.edit-module{min-height:100vh;background:#f5f5f5}.edit-content{max-width:1000px;margin:0 auto;padding:24px}.edit-header{margin-bottom:24px}.back-link{background:transparent;border:none;color:#9c27b0;cursor:pointer;font-size:14px;font-weight:500;padding:8px 0}.back-link:hover{text-decoration:underline}.edit-form{display:flex;flex-direction:column;gap:32px}.form-section{background:#fff;border-radius:12px;padding:24px;border:1px solid #e0e0e0}.form-section h2{font-size:20px;font-weight:600;color:#333;margin:0 0 20px}.form-group{margin-bottom:20px}.form-group label{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:8px}.form-group input,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#9c27b0}.questions-section{background:#fff;border-radius:12px;padding:24px;border:1px solid #e0e0e0}.questions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.questions-header h2{font-size:20px;font-weight:600;color:#333;margin:0}.add-question-btn{padding:10px 20px;background:#9c27b0;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;font-size:14px}.question-edit-card{position:relative;background:#f3e5f5;border:2px solid #e0e0e0;border-right:4px solid #9c27b0;border-radius:8px;padding:16px 20px 20px;margin-bottom:20px}.question-header{display:flex;align-items:center;margin-bottom:12px;min-height:0}.question-number-circle{width:32px;height:32px;border-radius:50%;background:#9c27b0;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.question-header h3{margin:0;font-size:16px;color:#333}.delete-question-btn{position:absolute;top:8px;right:8px;z-index:1;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:50%;cursor:pointer;padding:0;flex-shrink:0;color:#00000080;transition:background-color .15s ease,color .15s ease}.delete-question-icon{width:20px;height:20px;display:block;flex-shrink:0}.delete-question-btn:hover:not(:disabled){background:#00000012;color:#000000bf}.delete-question-btn:focus-visible{outline:2px solid #9c27b0;outline-offset:2px}.delete-question-btn:disabled{cursor:not-allowed;color:#0003}.question-text-input{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;margin-bottom:16px;resize:vertical}.response-type-group{margin-bottom:16px}.response-type-group label:first-child{display:block;font-size:14px;font-weight:500;color:#333;margin-bottom:12px}.radio-group{display:flex;flex-direction:column;gap:16px;padding:12px;background:#fafafa;border-radius:8px;margin-top:8px}.radio-group label{display:flex;align-items:center;gap:12px;cursor:pointer;font-weight:400;padding:8px 12px;border-radius:6px;transition:background-color .2s}.radio-group label:hover{background-color:#f0f0f0}.radio-group input[type=radio]{width:20px;height:20px;cursor:pointer;accent-color:#9c27b0;flex-shrink:0}.field-assignment-type-hint{margin:-4px 0 0;padding:0 12px 8px 40px;font-size:13px;color:#555;line-height:1.45;max-width:520px}.mcq-options-section{margin-top:16px;padding-top:16px;border-top:1px solid #e0e0e0}.mcq-options-intro{margin-bottom:14px}.mcq-options-title{display:block;font-size:14px;font-weight:600;color:#333;margin-bottom:6px}.mcq-options-help{margin:0;font-size:13px;line-height:1.45;color:#555}.mcq-options-grid{display:grid;grid-template-columns:4.75rem minmax(0,1fr) auto;align-items:center;column-gap:12px;row-gap:10px}.mcq-col-head{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:#666;padding-bottom:2px;border-bottom:1px solid #e8e8e8}.mcq-col-head-correct{text-align:center}.mcq-col-head-text{text-align:left}.mcq-col-head-remove{width:28px}.mcq-correct-cell{display:flex;justify-content:center;align-items:center}.mcq-correct-cell input[type=radio]{width:20px;height:20px;cursor:pointer;accent-color:#9c27b0;flex-shrink:0}.mcq-text-cell input[type=text]{width:100%;box-sizing:border-box;padding:8px 12px;border:1px solid #ddd;border-radius:8px;background:#fff}.mcq-remove-cell{display:flex;justify-content:center}.add-option-btn{padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;cursor:pointer;font-size:14px;margin-top:12px}.remove-option-btn{background:transparent;border:none;color:#c62828;cursor:pointer;font-size:20px;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.remove-option-btn:hover{background:#ffebee;border-radius:4px}.update-question-btn{margin-top:12px;padding:8px 16px;background:#9c27b0;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.update-question-btn:hover{background:#7b1fa2}.update-section{display:flex;justify-content:flex-end;padding-top:24px;border-top:1px solid #e0e0e0}.update-button{padding:14px 32px;background:#9c27b0;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;transition:background .3s}.update-button:hover{background:#7b1fa2}.edit-title{font-size:20px;font-weight:600;color:#1976d2;margin:8px 0}.post-button{padding:14px 32px;background:#2196f3;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;font-size:16px;margin-left:12px;transition:background .3s}.post-button:hover{background:#1976d2}.new-question-highlight{animation:highlightPulse 2s ease-in-out}@keyframes highlightPulse{0%{background-color:#f3e5f5}50%{background-color:#e1bee7}to{background-color:#f3e5f5}}.teacher-announcements{min-height:100vh;min-height:100dvh;background:#f5f5f5}.announcements-content{max-width:1200px;margin:0 auto;padding:24px;width:100%;box-sizing:border-box}.announcements-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.announcements-header h1{font-size:24px;font-weight:600;color:#333;margin:0}.create-button{padding:10px 20px;background:#333;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.create-button:hover{background:#555}.announcements-list{display:flex;flex-direction:column;gap:16px;width:100%}.announcements-pagination{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px 16px;margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.announcements-page-btn{padding:8px 16px;font-size:14px;font-weight:500;font-family:inherit;color:#333;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:background .2s ease,border-color .2s ease}.announcements-page-btn:hover:not(:disabled){background:#eee;border-color:#ccc}.announcements-page-btn:disabled{opacity:.45;cursor:not-allowed}.announcements-page-info{font-size:14px;color:#555;text-align:center}.announcements-page-range{color:#888;font-size:13px}.no-announcements{padding:48px;text-align:center;background:#fff;border-radius:12px;border:1px solid #e0e0e0}.no-announcements p{font-size:16px;color:#666;margin:0}.announcement-card{display:flex;justify-content:space-between;align-items:flex-start;background:#e3f2fd;border-radius:12px;padding:20px;border:1px solid #e0e0e0;overflow:visible}.announcement-content{flex:1;min-width:0;overflow-wrap:break-word;word-break:break-word}.announcement-content h3{font-size:18px;font-weight:600;color:#333;margin:0 0 8px}.announcement-content p{font-size:14px;color:#666;margin:0 0 12px}.announcement-date{font-size:12px;color:#999;margin-right:8px}.posted-badge{padding:4px 8px;background:#4caf50;color:#fff;border-radius:12px;font-size:11px;font-weight:500}.announcement-actions{display:flex;gap:8px;align-items:center}.edit-btn,.delete-btn{background:transparent;border:none;cursor:pointer;font-size:18px;opacity:.6;padding:8px;transition:all .2s}.edit-btn:hover{opacity:1;background:#e3f2fd;border-radius:4px}.delete-btn:hover{opacity:1;background:#ffebee;border-radius:4px}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#fff;border-radius:12px;padding:32px;width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-content h2{margin:0 0 24px;font-size:24px;font-weight:600;color:#333}.modal-content .form-field{margin-bottom:20px}.modal-content .form-field label{display:block;margin-bottom:8px;font-weight:500;color:#333}.modal-content .form-field input,.modal-content .form-field textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit}.modal-content .form-field textarea{resize:vertical}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-actions button{padding:10px 20px;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.modal-actions button[type=button]{background:#f5f5f5;color:#333}.modal-actions button[type=button]:hover{background:#e0e0e0}.modal-actions button[type=submit]{background:#333;color:#fff}.modal-actions button[type=submit]:hover{background:#555}.teacher-settings{min-height:100vh;background:#f5f5f5}.teacher-settings *{box-sizing:border-box}.settings-content{max-width:1200px;margin:0 auto;padding:24px}.zoom-card{min-width:0}.zoom-description{font-size:14px;color:#666;margin:0 0 20px}.zoom-form{display:flex;flex-direction:column;gap:16px;width:100%}.zoom-form .form-group{display:flex;flex-direction:column;gap:8px;width:100%;min-width:0;box-sizing:border-box}.zoom-form label{font-size:14px;font-weight:500;color:#333}.zoom-form input{width:100%;padding:12px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;font-size:14px;box-sizing:border-box}.zoom-form input:focus{outline:none;border-color:#9c27b0;background:#fff}.zoom-link-row{display:flex;gap:12px;align-items:center}.zoom-link-row input{flex:1;min-width:0}.update-zoom-button{flex-shrink:0;padding:12px 24px;background:#333;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s}.update-zoom-button:hover{background:#555}.settings-content h1{font-size:24px;font-weight:600;color:#333;margin:0 0 24px}.course-selector-section{margin-bottom:24px;padding:16px;background:#fff;border-radius:8px;border:1px solid #e0e0e0;display:flex;align-items:center;gap:12px;flex-wrap:wrap}.course-selector-section label{font-size:14px;font-weight:500;color:#333}.course-select{flex:1;max-width:400px;padding:10px 36px 10px 12px;background:#f5f5f5 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat right 12px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #ddd;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.course-select:focus{outline:none;border-color:#9c27b0;background:#fff}.no-courses-message{font-size:14px;color:#666;margin:0;flex:1}.create-course-button{padding:10px 20px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.create-course-button:hover{background:#7b1fa2;transform:translateY(-1px);box-shadow:0 2px 6px #9c27b04d}.create-course-card{margin-bottom:24px}.create-course-description{font-size:14px;color:#666;margin:0 0 20px}.create-course-form{display:flex;flex-direction:column;gap:16px}.create-course-form .form-group{display:flex;flex-direction:column;gap:8px}.create-course-form label{font-size:14px;font-weight:500;color:#333}.course-name-input,.course-description-input{padding:12px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit}.course-name-input:focus,.course-description-input:focus{outline:none;border-color:#9c27b0;background:#fff}.course-description-input{resize:vertical;min-height:80px}.create-course-submit-button{padding:12px 24px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;align-self:flex-start}.create-course-submit-button:hover:not(:disabled){background:#7b1fa2;transform:translateY(-1px);box-shadow:0 2px 6px #9c27b04d}.create-course-submit-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.source-course-select{padding:12px 36px 12px 12px;background:#f5f5f5 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat right 12px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;cursor:pointer;transition:all .2s}.source-course-select:focus{outline:none;border-color:#9c27b0;background:#fff}.copy-note{display:block;font-size:12px;color:#666;margin-top:8px;font-style:italic}.settings-grid{display:flex;flex-direction:column;gap:24px}.settings-card{background:#fff;border-radius:12px;padding:24px;border:1px solid #e0e0e0;box-sizing:border-box;min-width:0}.settings-card h2{font-size:18px;font-weight:600;color:#333;margin:0 0 16px}.student-code-card{background:linear-gradient(135deg,#f3e5f5,#e1bee7)}.teacher-code-card{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.code-display{display:flex;gap:12px;align-items:center}.code-input{flex:1;padding:12px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:Courier New,monospace}.copy-button{padding:12px 20px;background:#666;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;white-space:nowrap}.copy-button:hover{background:#555}.ceu-description{font-size:14px;color:#666;margin:0 0 20px}.ceu-form{display:flex;flex-direction:column;gap:16px}.ceu-form .form-group{display:flex;flex-direction:column;gap:8px}.ceu-form label{font-size:14px;font-weight:500;color:#333}.ceu-form input{padding:12px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;font-size:14px}.ceu-form input:focus{outline:none;border-color:#9c27b0;background:#fff}.update-ceu-button{padding:12px 24px;background:#333;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;align-self:flex-start}.update-ceu-button:hover{background:#555}.people-subsection{margin:0}.people-subsection-title{font-size:15px;font-weight:600;color:#333;margin:0 0 6px}.people-subsection-description{font-size:14px;color:#666;margin:0 0 16px}.people-divider{height:1px;background:#e0e0e0;margin:24px 0}.enrollment-code-readonly{display:flex;align-items:center;gap:12px}.enrollment-code-value{font-size:18px;font-weight:700;color:#9c27b0;letter-spacing:4px;padding:12px 20px;background:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.copy-code-button{padding:12px 24px;background:#333;color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s;white-space:nowrap}.copy-code-button:hover{background:#555}.no-code-message{font-size:14px;color:#999;margin:0}.add-teacher-toggle-button{padding:10px 20px;background:#333;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.add-teacher-toggle-button:hover{background:#7b1fa2;transform:translateY(-1px);box-shadow:0 2px 6px #9c27b04d}.add-teacher-form{display:flex;flex-direction:column;gap:16px}.add-teacher-form .form-group{display:flex;flex-direction:column;gap:8px}.add-teacher-form label{font-size:14px;font-weight:500;color:#333}.add-teacher-form input[type=text],.add-teacher-form input[type=email]{width:100%;padding:12px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;font-size:14px;box-sizing:border-box}.add-teacher-form input[type=text]:focus,.add-teacher-form input[type=email]:focus{outline:none;border-color:#9c27b0;background:#fff}.add-teacher-form-row{display:flex;gap:16px;width:100%}.add-teacher-form-row .form-group{flex:1;min-width:0}.course-select-list{display:flex;flex-wrap:wrap;gap:8px}.course-select-item{padding:8px 16px;background:#f5f5f5;border:1px solid #ddd;border-radius:20px;font-size:14px;color:#333;cursor:pointer;transition:all .2s}.course-select-item:hover{border-color:#9c27b0;background:#faf0fc}.course-select-item.selected{background:#9c27b0;color:#fff;border-color:#9c27b0}.course-select-item.selected:hover{background:#7b1fa2}.add-teacher-actions{display:flex;gap:12px;align-items:center}.add-teacher-submit-button{padding:12px 24px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.add-teacher-submit-button:hover:not(:disabled){background:#7b1fa2;transform:translateY(-1px);box-shadow:0 2px 6px #9c27b04d}.add-teacher-submit-button:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.add-teacher-cancel-button{padding:12px 24px;background:transparent;color:#666;border:1px solid #ddd;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.add-teacher-cancel-button:hover{background:#f5f5f5;border-color:#ccc}.resources-description{font-size:14px;color:#666;margin:0 0 20px}.resources-list{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.resource-item{padding:16px;background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px}.resource-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.resource-item-title{font-size:15px;font-weight:600;color:#333;margin:0 0 4px}.resource-item-description{font-size:13px;color:#666;margin:0}.resource-item-actions{display:flex;gap:8px;flex-shrink:0}.resource-edit-btn,.resource-delete-btn{padding:4px 12px;border:1px solid #ddd;border-radius:6px;font-size:12px;cursor:pointer;background:#fff;color:#666;transition:all .2s}.resource-edit-btn:hover{border-color:#9c27b0;color:#9c27b0}.resource-delete-btn:hover{border-color:#e53935;color:#e53935}.resource-item-links{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.resource-link-pill{padding:6px 14px;background:#e8eaf6;color:#1a237e;border-radius:20px;font-size:13px;text-decoration:none;transition:all .2s}.resource-link-pill:hover{background:#c5cae9}.resource-link-pill-pdf{background:#ffebee;color:#b71c1c}.resource-link-pill-pdf:hover{background:#ffcdd2}.add-resource-button{padding:10px 20px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.add-resource-button:hover{background:#7b1fa2;transform:translateY(-1px);box-shadow:0 2px 6px #9c27b04d}.resource-form{display:flex;flex-direction:column;gap:16px;padding:20px;background:#fafafa;border:1px solid #e0e0e0;border-radius:8px}.resource-form .form-group{display:flex;flex-direction:column;gap:8px}.resource-form label{font-size:14px;font-weight:500;color:#333}.resource-form input[type=text],.resource-form textarea{width:100%;padding:10px 12px;background:#fff;border:1px solid #ddd;border-radius:8px;font-size:14px;font-family:inherit;box-sizing:border-box}.resource-form input[type=text]:focus,.resource-form textarea:focus{outline:none;border-color:#9c27b0}.resource-form textarea{resize:vertical;min-height:60px}.resource-links-editor{display:flex;flex-direction:column;gap:8px}.resource-link-row{display:flex;gap:8px;align-items:center}.resource-link-label-input{flex:1;min-width:0}.resource-link-url-input{flex:2;min-width:0}.resource-link-remove{width:32px;height:32px;padding:0;background:transparent;border:1px solid #ddd;border-radius:6px;font-size:18px;color:#999;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.resource-link-remove:hover{border-color:#e53935;color:#e53935}.resource-add-link-btn{padding:6px 12px;background:transparent;border:1px dashed #ccc;border-radius:6px;font-size:13px;color:#666;cursor:pointer;align-self:flex-start;transition:all .2s}.resource-add-link-btn:hover{border-color:#9c27b0;color:#9c27b0}.resource-link-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.resource-upload-pdf-btn{padding:6px 12px;background:#fafafa;border:1px solid #ccc;border-radius:6px;font-size:13px;color:#333;cursor:pointer;transition:all .2s}.resource-upload-pdf-btn:hover:not(:disabled){border-color:#9c27b0;color:#7b1fa2}.resource-upload-pdf-btn:disabled{opacity:.6;cursor:not-allowed}.resource-pdf-input-hidden{position:absolute;width:1px;height:1px;opacity:0;overflow:hidden;clip:rect(0,0,0,0)}.resource-pdf-badge{flex:2;min-width:0;font-size:13px;color:#555;padding:8px 10px;background:#f5f5f5;border-radius:6px;border:1px solid #e0e0e0}.resource-form-actions{display:flex;gap:12px}.resource-save-btn{padding:10px 24px;background:#9c27b0;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.resource-save-btn:hover:not(:disabled){background:#7b1fa2}.resource-save-btn:disabled{background:#ccc;cursor:not-allowed}.resource-cancel-btn{padding:10px 24px;background:transparent;color:#666;border:1px solid #ddd;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.resource-cancel-btn:hover{background:#f5f5f5}.danger-description{font-size:14px;color:#666;margin:0 0 20px}.delete-course-button{padding:12px 24px;background:#e53935;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.delete-course-button:hover:not(:disabled){background:#c62828}.delete-course-button:disabled{background:#ccc;cursor:not-allowed}.teacher-grading{min-height:100vh;background:#f5f5f5}.grading-content{max-width:1200px;margin:0 auto;padding:24px}.teacher-course-title{font-size:24px;font-weight:600;color:#000;margin:0 0 16px}.teacher-nav{display:flex;gap:8px;margin-bottom:32px;border-bottom:1px solid #e0e0e0;padding-bottom:8px}.teacher-nav button{padding:10px 20px;background:transparent;border:none;border-radius:20px;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .2s}.teacher-nav button:hover{background:#f0f0f0}.teacher-nav button.active{background:#e0e0e0;color:#333}.course-indicator-banner{display:flex;align-items:center;gap:12px;padding:16px 24px;background:#4a148c;color:#fff;border-radius:8px;margin-bottom:24px;width:100%}.course-indicator-label{font-size:14px;font-weight:500;opacity:.9}.course-indicator-name{font-size:18px;font-weight:600}.grading-content h1{font-size:24px;font-weight:600;color:#333;margin:0 0 24px}.grading-selectors{display:inline-flex;gap:24px;margin-bottom:32px;padding:14px 20px;background:#f3e5f5;border-radius:10px;border:1px solid #e1bee7}.selector-group{display:flex;flex-direction:column;gap:8px;max-width:400px}.selector-group label{font-size:14px;font-weight:500;color:#333}.course-select,.module-select{padding:10px 36px 10px 12px;background:#f8f0f8 url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23666' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") no-repeat right 12px center;-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid #ce93d8;border-radius:8px;font-size:14px;cursor:pointer;transition:all .2s}.course-select:focus,.module-select:focus{outline:none;border-color:#9c27b0;background:#fff}.grading-container{background:#fff;border-radius:12px;border:1px solid #e0e0e0;overflow:hidden}.grading-header{padding:20px 24px;border-bottom:1px solid #e0e0e0}.grading-header h2{font-size:20px;font-weight:600;color:#333;margin:0 0 8px}.module-info{font-size:14px;color:#666;margin:0}.grading-table-wrapper{overflow-x:auto}.grading-table{width:100%;border-collapse:collapse}.grading-table thead{background:#f9f9f9}.grading-table th{padding:16px 12px;text-align:left;font-size:14px;font-weight:600;color:#333;border-bottom:2px solid #e0e0e0;white-space:nowrap}.student-name-col{min-width:200px;position:sticky;left:0;background:#f9f9f9;z-index:1}.question-col{min-width:150px;text-align:center}.total-col{min-width:100px;text-align:center;font-weight:700}.question-header{display:flex;flex-direction:column;align-items:center;gap:4px}.question-number{font-size:14px;font-weight:600}.question-points{font-size:12px;color:#666;font-weight:400}.grading-table tbody tr{border-bottom:1px solid #f0f0f0}.grading-table tbody tr:hover{background:#fafafa}.grading-table tbody tr.no-submission{opacity:.6}.student-name-cell{position:sticky;left:0;background:#fff;z-index:1;padding:16px 12px}.grading-table tbody tr:hover .student-name-cell{background:#fafafa}.student-info{display:flex;flex-direction:column;gap:4px}.student-name{font-size:14px;font-weight:500;color:#333}.no-submission-badge{font-size:11px;color:#999;font-style:italic}.grade-cell{padding:12px;text-align:center;vertical-align:top}.grade-input-container{display:flex;flex-direction:column;gap:8px;align-items:center;min-width:150px}.grade-input-group{display:flex;align-items:center;gap:4px;justify-content:center}.grade-input{width:60px;padding:6px 8px;border:1px solid #ddd;border-radius:6px;font-size:14px;text-align:center}.grade-input:focus{outline:none;border-color:#9c27b0}.grade-out-of{font-size:12px;color:#666}.grade-comment-input{width:100%;padding:6px 8px;border:1px solid #ddd;border-radius:6px;font-size:12px;font-family:inherit;resize:vertical;min-height:40px;max-height:80px}.grade-comment-input:focus{outline:none;border-color:#9c27b0}.grade-comment-input::placeholder{color:#999;font-style:italic}.save-grade-btn{padding:6px 12px;background:#9c27b0;color:#fff;border:none;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.save-grade-btn:hover:not(:disabled){background:#7b1fa2}.save-grade-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.saved-indicator{color:#4caf50;font-size:16px;font-weight:700}.no-submission-text{color:#999;font-style:italic}.total-cell{padding:16px 12px;text-align:center;font-weight:600}.total-score{font-size:14px;color:#333}.select-module-message,.no-questions-message{text-align:center;padding:48px 24px;background:#fff;border-radius:12px;border:1px solid #e0e0e0}.select-module-message p,.no-questions-message p{font-size:16px;color:#666;margin:0}.students-grading-list{display:flex;flex-direction:column;gap:32px;padding:24px}.submission-group{display:flex;flex-direction:column;gap:24px}.submission-group-header{font-size:18px;font-weight:600;color:#333;margin:0 0 8px;padding-bottom:12px;border-bottom:2px solid #e0e0e0}.student-grading-card{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:0;overflow:hidden}.student-grading-card>*:not(.student-card-header-toggle){padding:24px}.student-card-header-toggle{width:100%;display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#f5f5f5;border:1px solid #e0e0e0;border-radius:8px;cursor:pointer;transition:all .2s;margin-bottom:0}.student-card-header-toggle:hover{background:#eee}.student-card-header-content{display:flex;justify-content:space-between;align-items:center;flex:1}.student-toggle-arrow{font-size:14px;color:#666;transition:transform .2s;margin-left:16px}.student-toggle-arrow.expanded{transform:rotate(180deg)}.student-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #e0e0e0}.student-name-header{font-size:20px;font-weight:600;color:#333;margin:0}.student-total-grade{font-size:16px;color:#666}.student-total-grade strong{color:#333;font-size:18px}.graded-count-note{font-size:13px;color:#999;font-weight:400}.no-submission-message{text-align:center;padding:40px;color:#999;font-style:italic}.questions-grading-list{display:flex;flex-direction:column;gap:20px}.question-grading-card{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:20px}.question-header-grading{display:flex;align-items:center;gap:12px;margin-bottom:12px}.question-number-grading{font-size:16px;font-weight:600;color:#333;margin:0}.question-points-grading{font-size:14px;color:#666}.question-text-grading{font-size:15px;color:#333;margin:0 0 20px;line-height:1.5}.student-response-section{background:#f9f9f9;border:1px solid #e0e0e0;border-radius:8px;padding:16px;margin-bottom:20px}.response-label{font-size:14px;font-weight:600;color:#666;margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.response-display{margin-top:12px}.mcq-response-display{display:flex;flex-direction:column;gap:8px}.mcq-option-display{display:flex;align-items:center;gap:12px;padding:12px;background:#fff;border:2px solid #e0e0e0;border-radius:6px;transition:all .2s}.mcq-option-display.selected{border-color:#9c27b0;background:#f3e5f5}.mcq-option-display.answer-key{border-color:#2e7d32;background:#e8f5e9}.mcq-option-display.selected.answer-key{border-color:#2e7d32;background:#c8e6c9}.mcq-option-display.incorrect-selection{border-color:#c62828;background:#ffebee}.selected-badge.selected-correct{background:#2e7d32}.selected-badge.selected-wrong{background:#c62828}.answer-key-badge{padding:4px 8px;background:#2e7d32;color:#fff;border-radius:12px;font-size:11px;font-weight:600}.mcq-verdict{display:flex;align-items:flex-start;gap:10px;margin-top:12px;padding:12px 14px;border-radius:8px;font-size:14px;line-height:1.45}.mcq-verdict-correct{background:#e8f5e9;border:1px solid #a5d6a7;color:#1b5e20}.mcq-verdict-wrong{background:#fff3e0;border:1px solid #ffcc80;color:#5d4037}.mcq-verdict-wrong strong{color:#1b5e20;font-weight:600}.mcq-verdict-icon{flex-shrink:0;font-weight:700}.mcq-no-key-note{margin:12px 0 0;font-size:13px;color:#666;font-style:italic;line-height:1.4}.option-radio{font-size:18px;color:#9c27b0}.option-text{flex:1;font-size:14px;color:#333}.selected-badge{padding:4px 8px;background:#9c27b0;color:#fff;border-radius:12px;font-size:11px;font-weight:500}.audio-response-display{display:flex;flex-direction:column;gap:12px}.audio-submission-info{font-size:13px;color:#666;margin:0}.play-audio-btn{padding:10px 16px;background:#9c27b0;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;width:fit-content;transition:all .2s}.play-audio-btn:hover{background:#7b1fa2}.written-response-display{margin-top:8px}.response-textarea-readonly{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;background:#fff;color:#333;resize:vertical;min-height:100px}.no-response-message{padding:20px;text-align:center;color:#999;font-style:italic}.grading-section{background:#fff9e6;border:1px solid #ffd54f;border-radius:8px;padding:16px;margin-top:16px}.grading-label{font-size:14px;font-weight:600;color:#666;margin:0 0 16px;text-transform:uppercase;letter-spacing:.5px}.grading-inputs{display:flex;flex-direction:column;gap:16px}.grade-input-wrapper{display:flex;flex-direction:column;gap:8px}.grade-input-wrapper label{font-size:14px;font-weight:500;color:#333}.grade-input-group-new{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.grade-input-new{width:72px;height:40px;padding:0 8px;border:1px solid #ddd;border-radius:8px;font-size:16px;text-align:center;font-weight:500;-moz-appearance:textfield;appearance:textfield}.grade-input-new::-webkit-inner-spin-button,.grade-input-new::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.grade-input-new:focus{outline:none;border-color:#9c27b0;box-shadow:0 0 0 2px #9c27b026}.grade-out-of-new{font-size:14px;color:#666;font-weight:500}.comment-input-wrapper{display:flex;flex-direction:column;gap:8px}.comment-input-wrapper label{font-size:14px;font-weight:500;color:#333}.grade-comment-input-new{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit;resize:vertical;min-height:100px}.grade-comment-input-new:focus{outline:none;border-color:#9c27b0}.save-grade-wrapper{display:flex;align-items:center;gap:12px}.save-grade-btn-new{padding:10px 20px;background:#9c27b0;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.save-grade-btn-new:hover:not(:disabled){background:#7b1fa2}.save-grade-btn-new:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.grade-status-indicator{padding:8px 12px;background:#e8f5e9;border-radius:6px;border:1px solid #c8e6c9}.saved-indicator-new{color:#4caf50;font-size:14px;font-weight:500}.submit-all-grades-section{margin-top:24px;padding-top:20px;border-top:2px solid #e0e0e0;display:flex;flex-direction:column;align-items:center;gap:8px}.submit-all-grades-btn{padding:12px 32px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s}.submit-all-grades-btn:hover:not(:disabled){background:#45a049;transform:translateY(-1px);box-shadow:0 4px 8px #0003}.submit-all-grades-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.6}.submit-all-hint{font-size:13px;color:#666;margin:0;font-style:italic}@media(max-width:768px){.grading-selectors{flex-direction:column}.student-card-header{flex-direction:column;align-items:flex-start;gap:8px}}.student-card-header-row{display:flex;align-items:center;gap:4px}.student-card-header-row .student-card-header-toggle{flex:1;min-width:0}.reset-password-btn{padding:6px 10px;background:transparent;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s;flex-shrink:0}.reset-password-btn:hover{background:#fff3e0;border-color:#ff9800}.reset-password-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.reset-password-modal{background:#fff;border-radius:12px;padding:32px;width:100%;max-width:420px;box-shadow:0 8px 32px #0003;display:flex;flex-direction:column;gap:16px}.reset-password-modal h3{font-size:20px;font-weight:600;color:#333;margin:0}.reset-password-info{font-size:14px;color:#666;margin:0}.reset-password-field{display:flex;flex-direction:column;gap:6px}.reset-password-field label{font-size:14px;font-weight:500;color:#333}.reset-password-field input{padding:10px 12px;border:1px solid #ddd;border-radius:8px;font-size:14px;background:#f9f9f9}.reset-password-field input:focus{outline:none;border-color:#9c27b0;background:#fff}.reset-password-actions{display:flex;gap:12px;margin-top:4px}.reset-password-submit{flex:1;padding:10px 20px;background:#ff9800;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.reset-password-submit:hover:not(:disabled){background:#f57c00}.reset-password-submit:disabled{background:#ccc;cursor:not-allowed}.reset-password-cancel{padding:10px 20px;background:transparent;color:#666;border:1px solid #ddd;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.reset-password-cancel:hover{background:#f5f5f5}.link-response-display{display:flex;flex-direction:column;gap:6px;padding:12px 16px;background:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.link-response-label{font-size:12px;color:#666;font-weight:500}.link-response-url{color:#1976d2;font-size:14px;word-break:break-all;text-decoration:none}.link-response-url:hover{text-decoration:underline}.field-assignment-response-display{padding:12px 16px;background:#f5f5f5;border-radius:8px;border:1px solid #e0e0e0}.field-assignment-grade-line{margin:0 0 10px;font-size:14px;color:#333;word-break:break-word}.field-assignment-grade-line:last-child{margin-bottom:0}.field-assignment-ref{font-size:13px;color:#666}.app-container{min-height:100vh}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:#666}.error{color:#c62828;background:#ffebee;padding:12px;border-radius:8px;margin:16px 0}.success{color:#2e7d32;background:#e8f5e9;padding:12px;border-radius:8px;margin:16px 0}
