.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:#fff;border-bottom:1px solid var(--gray-200);padding:0 24px;height:64px;display:flex;align-items:center;gap:32px}.header-brand{font-size:20px;font-weight:600}.brand-link{color:var(--primary);text-decoration:none}.header-nav{display:flex;gap:8px;flex:1}.nav-link{padding:8px 16px;border-radius:4px;color:var(--gray-600);text-decoration:none;transition:background-color .2s}.nav-link:hover{background-color:var(--gray-100);text-decoration:none}.nav-link.active{background-color:var(--primary);color:#fff}.header-user{display:flex;align-items:center;gap:16px}.user-email{color:var(--gray-600);font-size:14px}.logout-button{padding:8px 16px;background:none;border:1px solid var(--gray-300);border-radius:4px;color:var(--gray-600);cursor:pointer;transition:all .2s}.logout-button:hover{background-color:var(--gray-100);border-color:var(--gray-600)}.nav-divider{width:1px;height:20px;background:var(--gray-300);margin:0 4px}.role-badge{font-size:11px;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:3px;background:var(--primary);color:#fff}.main-content{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.landing{min-height:100vh;display:flex;flex-direction:column}.landing-header{display:flex;justify-content:space-between;align-items:center;padding:16px 48px;background:#fff;border-bottom:1px solid var(--gray-200)}.landing-brand{font-size:24px;font-weight:700;color:var(--primary)}.landing-nav{display:flex;gap:16px}.landing-nav .nav-link{padding:10px 20px;border-radius:6px;font-weight:500;text-decoration:none;transition:all .2s}.landing-nav .nav-link:hover{text-decoration:none}.landing-nav .nav-link.primary{background:var(--primary);color:#fff}.landing-nav .nav-link.primary:hover{background:var(--primary-dark)}.landing-main{flex:1}.hero{text-align:center;padding:80px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.hero-title{font-size:48px;font-weight:700;margin-bottom:16px;max-width:800px;margin-left:auto;margin-right:auto}.hero-subtitle{font-size:20px;opacity:.9;max-width:600px;margin:0 auto 32px}.hero-actions{display:flex;gap:16px;justify-content:center}.btn-large{padding:16px 32px;font-size:18px}.btn-primary{background:#fff;color:var(--primary)}.btn-primary:hover{background:var(--gray-100)}.btn-secondary{background:transparent;color:#fff;border:2px solid white}.btn-secondary:hover{background:#ffffff1a}.features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:32px;padding:80px 48px;max-width:1200px;margin:0 auto}.feature{text-align:center;padding:24px}.feature-icon{font-size:48px;margin-bottom:16px}.feature h3{font-size:24px;margin-bottom:12px;color:var(--gray-800)}.feature p{color:var(--gray-600);line-height:1.6}.how-it-works{background:#fff;padding:80px 48px;text-align:center}.how-it-works h2{font-size:36px;margin-bottom:48px;color:var(--gray-800)}.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:32px;max-width:1000px;margin:0 auto}.step{padding:24px}.step-number{width:48px;height:48px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;margin:0 auto 16px}.step h4{font-size:18px;margin-bottom:8px;color:var(--gray-800)}.step p{color:var(--gray-600);font-size:14px}.landing-footer{background:var(--gray-800);color:#fff;text-align:center;padding:24px}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:24px}.auth-container{background:#fff;border-radius:12px;padding:40px;width:100%;max-width:440px;box-shadow:0 10px 40px #0003}.auth-header{text-align:center;margin-bottom:32px}.auth-brand{font-size:24px;font-weight:700;color:var(--primary);text-decoration:none;display:block;margin-bottom:24px}.auth-header h1{font-size:28px;color:var(--gray-800);margin-bottom:8px}.auth-header p{color:var(--gray-600)}.auth-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:500;color:var(--gray-800);font-size:14px}.form-group input{padding:12px 16px;border:1px solid var(--gray-200);border-radius:6px;font-size:16px;transition:border-color .2s,box-shadow .2s}.form-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0078d41a}.form-group small{color:var(--gray-600);font-size:12px}.error-message{background:#fde7e9;color:var(--error);padding:12px 16px;border-radius:6px;font-size:14px}.btn-full{width:100%}.btn-primary{background:var(--primary);color:#fff;padding:14px 24px;border-radius:6px;font-size:16px;font-weight:600;border:none;cursor:pointer;transition:background .2s}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:24px;padding-top:24px;border-top:1px solid var(--gray-200)}.auth-footer p{color:var(--gray-600)}.auth-footer a{color:var(--primary);font-weight:500}.dashboard{display:flex;flex-direction:column;gap:32px}.welcome-section h1{font-size:28px;color:var(--gray-800);margin-bottom:8px}.welcome-section p{color:var(--gray-600)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.stat-card{background:#fff;border-radius:8px;padding:24px;text-align:center;box-shadow:0 1px 3px #0000001a}.stat-value{font-size:36px;font-weight:700;color:var(--primary);margin-bottom:8px}.stat-label{color:var(--gray-600);font-size:14px}.dashboard-sections{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:24px}.dashboard-section{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{font-size:18px;color:var(--gray-800)}.view-all{color:var(--primary);font-size:14px}.assignments-preview{display:flex;flex-direction:column;gap:12px}.assignment-card{border:1px solid var(--gray-200);border-radius:6px;padding:16px}.assignment-card h3{font-size:16px;margin-bottom:8px;color:var(--gray-800)}.assignment-card p{font-size:14px;color:var(--gray-600);margin-bottom:12px}.assignment-meta{display:flex;justify-content:space-between;align-items:center}.points{font-size:14px;color:var(--primary);font-weight:500}.btn-small{padding:6px 12px;font-size:12px;background:var(--primary);color:#fff;border-radius:4px;text-decoration:none}.submissions-preview{display:flex;flex-direction:column;gap:8px}.submission-row{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid var(--gray-200)}.submission-row:last-child{border-bottom:none}.submission-info{display:flex;flex-direction:column;gap:4px}.submission-id{font-weight:500;color:var(--gray-800)}.submission-date{font-size:12px;color:var(--gray-600)}.score{font-weight:600;padding:4px 8px;border-radius:4px}.score.excellent{background:#dff6dd;color:var(--success)}.score.good{background:#e6f4ff;color:var(--primary)}.score.fair{background:#fff4ce;color:#986f0b}.score.needs-work{background:#fde7e9;color:var(--error)}.score.pending{background:var(--gray-100);color:var(--gray-600)}.empty-message{color:var(--gray-600);text-align:center;padding:24px}.quick-start{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.quick-start h2{font-size:18px;color:var(--gray-800);margin-bottom:16px}.quick-start ol{padding-left:24px;color:var(--gray-600)}.quick-start li{margin-bottom:8px}.assignments-page{display:flex;flex-direction:column;gap:24px}.assignments-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.assignment-card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;display:flex;flex-direction:column;overflow:hidden;transition:box-shadow .2s}.assignment-card:hover{box-shadow:0 4px 12px #00000026}.card-content{padding:24px;flex:1}.card-content h2{font-size:20px;color:var(--gray-800);margin-bottom:12px}.description{color:var(--gray-600);font-size:14px;line-height:1.6;margin-bottom:16px}.card-meta{display:flex;justify-content:space-between;font-size:13px}.max-score{color:var(--primary);font-weight:600}.card-actions{padding:16px 24px;background:var(--gray-100);border-top:1px solid var(--gray-200)}.card-actions .btn{width:100%;text-align:center;display:block}.empty-state,.error-state{text-align:center;padding:60px 24px;background:#fff;border-radius:8px}.empty-state p,.error-state{color:var(--gray-600)}.btn{display:inline-block;padding:12px 24px;border-radius:6px;font-weight:600;text-decoration:none;transition:all .2s;border:none;cursor:pointer}.btn-primary:hover{background:var(--primary-dark);text-decoration:none}.assignment-detail{max-width:800px}.detail-header h1{font-size:28px;color:var(--gray-800);margin-bottom:12px}.header-meta{display:flex;gap:16px;align-items:center}.points-badge{background:var(--primary);color:#fff;padding:4px 12px;border-radius:16px;font-size:14px;font-weight:600}.created-date{color:var(--gray-600);font-size:14px}.detail-content{display:flex;flex-direction:column;gap:24px}.detail-content section{background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.detail-content h2{font-size:18px;color:var(--gray-800);margin-bottom:16px}.description-section p{color:var(--gray-600);line-height:1.6}.instructions-section ol{padding-left:24px;color:var(--gray-600)}.instructions-section li{margin-bottom:8px;line-height:1.6}.best-score{background:#dff6dd;padding:12px 16px;border-radius:6px;margin-bottom:16px;display:flex;justify-content:space-between;align-items:center}.best-score span{color:var(--gray-600)}.best-score strong{color:var(--success);font-size:18px}.submissions-table th,.submissions-table td{padding:12px;text-align:left;border-bottom:1px solid var(--gray-200)}.submissions-table th{font-weight:600;color:var(--gray-800);background:var(--gray-100)}.no-submissions{text-align:center;padding:40px!important}.no-submissions p{color:var(--gray-600)}.submissions-page{display:flex;flex-direction:column;gap:24px}.page-header h1{font-size:28px;color:var(--gray-800);margin-bottom:8px}.page-header p{color:var(--gray-600)}.submissions-list{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow:hidden}.submissions-table{width:100%;border-collapse:collapse}.submissions-table th,.submissions-table td{padding:16px;text-align:left;border-bottom:1px solid var(--gray-200)}.submissions-table th{font-weight:600;color:var(--gray-800);background:var(--gray-100);font-size:14px}.submissions-table td{color:var(--gray-600)}.submissions-table tbody tr:hover{background:var(--gray-100)}.submissions-table a{color:var(--primary)}.score-badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:13px;font-weight:600}.score-badge.excellent{background:#dff6dd;color:var(--success)}.score-badge.good{background:#e6f4ff;color:var(--primary)}.score-badge.fair{background:#fff4ce;color:#986f0b}.score-badge.needs-work{background:#fde7e9;color:var(--error)}.score-badge.pending{background:var(--gray-200);color:var(--gray-600)}.view-link{color:var(--primary);font-weight:500}.empty-state{text-align:center;padding:60px 24px;background:#fff;border-radius:8px}.empty-state h2{color:var(--gray-800);margin-bottom:8px}.empty-state p{color:var(--gray-600);margin-bottom:24px}.btn{display:inline-block;padding:12px 24px;border-radius:6px;font-weight:600;text-decoration:none}.btn-primary:hover{text-decoration:none}.submission-detail{max-width:800px}.back-link{display:inline-block;margin-bottom:16px;color:var(--primary);font-size:14px}.detail-header{background:#fff;padding:24px;border-radius:8px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.detail-header h1{font-size:24px;color:var(--gray-800);margin-bottom:12px}.header-meta{display:flex;gap:16px;align-items:center;font-size:14px}.date{color:var(--gray-600)}.assignment-link{color:var(--primary)}.score-card{background:#fff;padding:32px;border-radius:8px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a;text-align:center}.score-display{display:flex;justify-content:center;align-items:baseline;gap:8px;margin-bottom:8px}.score-value{font-size:64px;font-weight:700;color:var(--primary)}.score-divider{font-size:40px;color:var(--gray-300)}.score-max{font-size:32px;color:var(--gray-600)}.score-percentage{font-size:24px;color:var(--gray-600);margin-bottom:16px}.score-bar{height:8px;background:var(--gray-200);border-radius:4px;overflow:hidden;max-width:400px;margin:0 auto}.score-fill{height:100%;background:var(--primary);border-radius:4px;transition:width .3s ease}.feedback-section{background:#fff;padding:24px;border-radius:8px;box-shadow:0 1px 3px #0000001a}.feedback-section h2{font-size:18px;color:var(--gray-800);margin-bottom:20px}.checks-list{display:flex;flex-direction:column;gap:12px}.check-item{display:flex;gap:16px;padding:16px;border-radius:6px;border:1px solid var(--gray-200)}.check-item.passed{border-left:4px solid var(--success)}.check-item.failed{border-left:4px solid var(--error)}.check-status{font-size:20px;font-weight:700;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;flex-shrink:0}.check-item.passed .check-status{background:#dff6dd;color:var(--success)}.check-item.failed .check-status{background:#fde7e9;color:var(--error)}.check-content{flex:1}.check-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.check-type{font-weight:600;color:var(--gray-800)}.check-location{background:var(--gray-100);padding:2px 8px;border-radius:4px;font-size:12px;color:var(--gray-600);font-family:monospace}.check-sheet{background:#e6f4ff;padding:2px 8px;border-radius:4px;font-size:12px;color:var(--primary)}.check-points{font-size:14px;color:var(--gray-600);margin-bottom:8px}.check-hint{background:#fff4ce;padding:8px 12px;border-radius:4px;font-size:14px;color:#986f0b;margin-bottom:8px}.check-feedback{font-size:14px;color:var(--gray-600)}.no-feedback{background:#fff;padding:40px;border-radius:8px;text-align:center;box-shadow:0 1px 3px #0000001a}.no-feedback p{color:var(--gray-600)}.my-courses{max-width:1000px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.page-header h1{margin:0}.empty-state{text-align:center;padding:48px 24px;background:#fff;border-radius:8px;border:1px solid var(--gray-200)}.empty-state h2{margin-bottom:8px;color:var(--gray-600)}.empty-state p{margin-bottom:16px;color:var(--gray-500)}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.course-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:20px}.course-card h3{margin:0 0 8px}.course-description{color:var(--gray-600);font-size:14px;margin-bottom:12px}.course-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--gray-500);margin-bottom:16px}.course-slug{font-family:monospace;background:var(--gray-100);padding:2px 6px;border-radius:3px}.course-actions{display:flex;gap:8px}.btn{display:inline-block;padding:8px 16px;border-radius:4px;border:1px solid var(--gray-300);background:#fff;color:var(--gray-700);cursor:pointer;text-decoration:none;font-size:14px;transition:all .2s}.btn:hover{background:var(--gray-100);text-decoration:none}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{opacity:.9}.btn-secondary{background:var(--gray-100)}.btn-danger{color:#dc2626;border-color:#dc2626}.btn-danger:hover{background:#fef2f2}.btn-small{padding:4px 12px;font-size:13px}.error-message{background:#fef2f2;color:#dc2626;padding:12px;border-radius:4px;margin-bottom:16px}.course-templates{max-width:1000px}.page-subtitle{color:var(--gray-500);margin-top:4px}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.template-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:24px;display:flex;flex-direction:column}.template-card h3{margin:0 0 8px}.template-description{color:var(--gray-600);font-size:14px;flex:1;margin-bottom:16px}.template-meta{font-size:13px;color:var(--gray-500);margin-bottom:16px}.clone-btn{text-align:center}.clone-course{max-width:600px}.clone-form{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:24px}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:500;margin-bottom:6px;color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0078d41a}.help-text{display:block;font-size:12px;color:var(--gray-500);margin-top:4px}.form-actions{display:flex;gap:8px;margin-top:24px}.course-editor{max-width:900px}.course-header-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:24px;margin-bottom:24px}.course-title-row{display:flex;justify-content:space-between;align-items:flex-start}.course-title-row h1{margin:0}.edit-form .form-group{margin-bottom:12px}.edit-form label{display:block;font-weight:500;margin-bottom:4px}.edit-form input,.edit-form textarea{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px}.module-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;margin-bottom:12px;overflow:hidden}.module-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--gray-50, #f9fafb);border-bottom:1px solid var(--gray-200)}.module-header h3{margin:0}.module-actions{display:flex;gap:4px}.items-list{padding:0}.item-row{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;border-bottom:1px solid var(--gray-100)}.item-row:last-child{border-bottom:none}.item-info{display:flex;align-items:center;gap:12px;flex:1}.item-type-badge{font-size:11px;font-weight:600;text-transform:uppercase;padding:2px 8px;border-radius:3px;white-space:nowrap}.item-type-badge.lesson{background:#dbeafe;color:#1d4ed8}.item-type-badge.assignment{background:#dcfce7;color:#166534}.item-type-badge.guided_lesson{background:#fef3c7;color:#92400e}.item-title{font-size:14px}.item-points{font-size:12px;color:var(--gray-500)}.item-actions{display:flex;gap:4px}.empty-module{padding:16px 20px;color:var(--gray-500);font-style:italic;font-size:14px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:8px;padding:24px;min-width:320px;max-width:480px;box-shadow:0 8px 32px #0003}.modal h3{margin:0 0 16px}.modal-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px}.modal-list-item{text-align:left;padding:10px 14px;border:1px solid var(--gray-200);border-radius:4px;background:#fff;cursor:pointer;font-size:14px;transition:background .15s}.modal-list-item:hover{background:var(--gray-100)}.missing-panel{background:#fffbeb;border:1px solid #f59e0b;border-radius:8px;padding:16px 20px;margin-bottom:24px}.missing-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.missing-header h3{margin:0;color:#92400e}.missing-list{display:flex;flex-direction:column;gap:8px}.missing-item-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#fff;border-radius:4px;border:1px solid var(--gray-200)}.missing-origin{font-size:12px;color:var(--gray-500);font-style:italic}.missing-actions select{padding:4px 8px;border:1px solid var(--gray-300);border-radius:4px;font-size:13px}.grading-settings{max-width:600px}.settings-form{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:24px}.settings-form .form-group{margin-bottom:20px}.settings-form label{display:block;font-weight:500;margin-bottom:6px;color:var(--gray-700)}.settings-form input[type=number],.settings-form select{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px}.settings-form input:focus,.settings-form select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0078d41a}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto}.success-message{background:#dcfce7;color:#166534;padding:12px;border-radius:4px;margin-bottom:16px}.assignment-overrides{max-width:1000px}.overrides-table-container{background:#fff;border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}.overrides-table{width:100%;border-collapse:collapse}.overrides-table th,.overrides-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--gray-200);font-size:14px}.overrides-table th{background:var(--gray-100);font-weight:600;color:var(--gray-700);font-size:12px;text-transform:uppercase;letter-spacing:.5px}.overrides-table tr:last-child td{border-bottom:none}.overrides-table tr:hover td{background:#f8f9fa}.module-group-header td{background:var(--gray-100)!important;font-weight:600;color:var(--gray-600);font-size:13px;padding:8px 14px}.assignment-title-cell{display:flex;align-items:center;gap:8px}.item-type-badge{display:inline-block;padding:2px 6px;border-radius:3px;font-size:10px;font-weight:600;text-transform:uppercase}.item-type-badge.assignment{background:#e8f0fe;color:#1a73e8}.item-type-badge.guided_lesson{background:#fef3e0;color:#e65100}.excluded-row td{opacity:.5;text-decoration:line-through}.due-date-cell{display:flex;align-items:center;gap:6px}.due-date-cell input[type=datetime-local]{padding:4px 8px;border:1px solid var(--gray-300);border-radius:4px;font-size:13px}.due-date-cell .btn-icon{padding:2px 6px;font-size:12px}.override-badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:500}.override-badge.active{background:#e8f5e9;color:#2e7d32}.override-badge.none{background:var(--gray-100);color:var(--gray-500)}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.override-modal{background:#fff;border-radius:8px;padding:24px;width:480px;max-height:80vh;overflow-y:auto;box-shadow:0 8px 32px #00000026}.override-modal h3{margin:0 0 16px}.override-modal .form-group{margin-bottom:16px}.override-modal label{display:block;font-weight:500;margin-bottom:4px;color:var(--gray-700);font-size:13px}.override-modal input[type=number],.override-modal select{width:100%;padding:6px 10px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px}.override-modal input:focus,.override-modal select:focus{outline:none;border-color:var(--primary)}.override-modal .checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer}.override-modal .form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid var(--gray-200)}.override-modal .placeholder-text{color:var(--gray-500);font-size:12px;margin-top:2px}.past-due{color:#d32f2f;font-weight:500}.admin-page{display:flex;flex-direction:column;gap:24px}.admin-layout{display:flex;min-height:calc(100vh - 64px)}.admin-sidebar{width:240px;background:#fff;border-right:1px solid var(--gray-200);padding:24px 0;flex-shrink:0}.admin-sidebar-header{padding:0 20px 16px;font-size:12px;font-weight:600;text-transform:uppercase;color:var(--gray-600);letter-spacing:.5px}.admin-sidebar-nav{display:flex;flex-direction:column;gap:2px}.admin-nav-link{display:flex;align-items:center;gap:10px;padding:10px 20px;color:var(--gray-600);text-decoration:none;font-size:14px;transition:background-color .2s,color .2s}.admin-nav-link:hover{background-color:var(--gray-100);color:var(--gray-800);text-decoration:none}.admin-nav-link.active{background-color:var(--primary);color:#fff}.admin-nav-link .nav-icon{width:18px;text-align:center;flex-shrink:0}.admin-nav-divider{height:1px;background:var(--gray-200);margin:8px 20px}.admin-content{flex:1;padding:24px 32px;max-width:1200px;overflow-x:auto}.admin-page .page-header{display:flex;justify-content:space-between;align-items:center}.admin-page .page-header h1{font-size:28px;color:var(--gray-800);margin:0}.admin-page .page-header p{color:var(--gray-600);margin-top:4px}.admin-page .page-header-actions{display:flex;gap:8px;align-items:center}.admin-toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.admin-toolbar input[type=text],.admin-toolbar input[type=search],.admin-toolbar select{padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:14px;background:#fff;color:var(--gray-800);transition:border-color .2s}.admin-toolbar input[type=text],.admin-toolbar input[type=search]{min-width:240px}.admin-toolbar input:focus,.admin-toolbar select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0078d41a}.admin-toolbar input::placeholder{color:var(--gray-300)}.admin-filter-count{font-size:13px;color:var(--gray-600);white-space:nowrap}.admin-tabs{display:flex;gap:0;border-bottom:2px solid var(--gray-200)}.admin-tab{padding:10px 20px;font-size:14px;font-weight:500;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;color:var(--gray-600);transition:color .2s,border-color .2s}.admin-tab:hover{color:var(--gray-800)}.admin-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.admin-table-wrap{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;font-size:14px}.admin-table thead{background:var(--gray-100)}.admin-table th{text-align:left;padding:12px 16px;border-bottom:2px solid var(--gray-200);color:var(--gray-600);font-weight:600;font-size:13px;white-space:nowrap}.admin-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s}.admin-table th.sortable:hover{background:var(--gray-200)}.admin-table th.sorted{color:var(--primary)}.admin-table td{padding:10px 16px;border-bottom:1px solid var(--gray-100);color:var(--gray-800)}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--gray-50, #f9fafb)}.admin-table .cell-muted{color:var(--gray-600);font-size:13px}.admin-table .cell-mono{font-family:monospace;font-size:13px;background:var(--gray-100);padding:2px 6px;border-radius:3px}.admin-table .cell-truncate{max-width:240px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-table-empty{text-align:center;padding:48px 24px;color:var(--gray-600)}.row-actions{display:flex;gap:6px;white-space:nowrap}.admin-table-footer{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-top:1px solid var(--gray-200);font-size:13px;color:var(--gray-600)}.admin-pagination{display:flex;gap:4px;align-items:center}.admin-pagination-btn{padding:6px 12px;border:1px solid var(--gray-300);border-radius:4px;background:#fff;color:var(--gray-800);cursor:pointer;font-size:13px;transition:all .2s}.admin-pagination-btn:hover:not(:disabled){background:var(--gray-100)}.admin-pagination-btn:disabled{opacity:.4;cursor:not-allowed}.admin-pagination-btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.admin-pagination-info{font-size:13px;color:var(--gray-600)}.admin-load-more{display:flex;justify-content:center;padding:16px 0}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px}.admin-stat-card{background:#fff;border-radius:8px;padding:20px;text-align:center;box-shadow:0 1px 3px #0000001a}.admin-stat-card .stat-value{font-size:32px;font-weight:700;color:var(--primary);margin-bottom:4px}.admin-stat-card .stat-value.success{color:var(--success)}.admin-stat-card .stat-value.warning{color:var(--warning)}.admin-stat-card .stat-value.error{color:var(--error)}.admin-stat-card .stat-label{color:var(--gray-600);font-size:13px}.admin-stat-card .stat-change{font-size:12px;margin-top:4px}.admin-stat-card .stat-change.positive{color:var(--success)}.admin-stat-card .stat-change.negative{color:var(--error)}.admin-template-builder{display:flex;gap:24px;align-items:flex-start}.admin-builder-panel{flex:1;background:#fff;border:1px solid var(--gray-200);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}.admin-builder-panel.narrow{flex:0 0 340px}.admin-builder-panel-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:var(--gray-100);border-bottom:1px solid var(--gray-200)}.admin-builder-panel-header h3{margin:0;font-size:16px;color:var(--gray-800)}.admin-builder-panel-body{padding:16px 20px;flex:1;overflow-y:auto;max-height:600px}.admin-builder-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid var(--gray-200);border-radius:4px;margin-bottom:8px;background:#fff;transition:background .15s;cursor:grab}.admin-builder-item:hover{background:var(--gray-100)}.admin-builder-item.dragging{opacity:.5;border-style:dashed}.admin-builder-item-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.admin-builder-item-title{font-size:14px;color:var(--gray-800);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-builder-item-meta{font-size:12px;color:var(--gray-600)}.admin-builder-item-actions{display:flex;gap:4px;flex-shrink:0}.admin-builder-empty{text-align:center;padding:32px 16px;color:var(--gray-600);font-style:italic;font-size:14px;border:2px dashed var(--gray-200);border-radius:6px}.admin-builder-drop-zone{border:2px dashed var(--primary);border-radius:6px;padding:16px;text-align:center;color:var(--primary);font-size:14px;background:#0078d40a;margin-bottom:8px}.admin-content-picker{background:#fff;border:1px solid var(--gray-200);border-radius:8px;overflow:hidden}.admin-content-picker-search{padding:12px 16px;border-bottom:1px solid var(--gray-200)}.admin-content-picker-search input{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px;box-sizing:border-box}.admin-content-picker-search input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0078d41a}.admin-content-picker-search input::placeholder{color:var(--gray-300)}.admin-content-picker-actions{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;background:var(--gray-100);border-bottom:1px solid var(--gray-200);font-size:13px;color:var(--gray-600)}.admin-content-picker-list{max-height:400px;overflow-y:auto}.admin-content-picker-item{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--gray-200);cursor:pointer;transition:background .15s}.admin-content-picker-item:last-child{border-bottom:none}.admin-content-picker-item:hover{background:var(--gray-100)}.admin-content-picker-item.selected{background:#0078d40f}.admin-content-picker-item input[type=checkbox]{flex-shrink:0}.admin-content-picker-item-info{flex:1;min-width:0}.admin-content-picker-item-title{font-size:14px;color:var(--gray-800)}.admin-content-picker-item-desc{font-size:12px;color:var(--gray-600);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-content-picker-empty{text-align:center;padding:24px 16px;color:var(--gray-600);font-size:14px}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;border:none;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all .2s}.btn:hover{text-decoration:none}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-secondary{background:var(--gray-100);color:var(--gray-800);border:1px solid var(--gray-300)}.btn-secondary:hover{background:var(--gray-200)}.btn-danger{background:#fde7e9;color:var(--error)}.btn-danger:hover{background:#fbd0d5}.btn-danger.filled{background:var(--error);color:#fff}.btn-danger.filled:hover{opacity:.9}.btn-success{background:var(--success);color:#fff}.btn-success:hover{opacity:.9}.btn-small{padding:4px 10px;font-size:12px}.btn-icon{background:none;border:1px solid var(--gray-300);border-radius:4px;padding:4px 8px;cursor:pointer;font-size:12px;color:var(--gray-600);transition:all .2s}.btn-icon:hover:not(:disabled){background:var(--gray-100)}.btn-icon:disabled{opacity:.3;cursor:not-allowed}.btn:disabled{opacity:.5;cursor:not-allowed}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:1000}.admin-modal{background:#fff;border-radius:10px;width:480px;max-width:90vw;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 40px #0003}.admin-modal.large{width:680px}.admin-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--gray-200)}.admin-modal-header h2{margin:0;font-size:20px;color:var(--gray-800)}.admin-modal-close{background:none;border:none;font-size:20px;color:var(--gray-600);cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .15s}.admin-modal-close:hover{background:var(--gray-100)}.admin-modal-body{padding:24px;overflow-y:auto;flex:1}.admin-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-top:1px solid var(--gray-200)}.admin-modal h2:first-child{font-size:20px;color:var(--gray-800);margin-bottom:20px}.admin-modal .form-group{margin-bottom:16px}.admin-modal .form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-800);margin-bottom:4px}.admin-modal .form-group input,.admin-modal .form-group select,.admin-modal .form-group textarea{width:100%;padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:14px;box-sizing:border-box}.admin-modal .form-group input:focus,.admin-modal .form-group select:focus,.admin-modal .form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0078d41a}.admin-modal .form-group textarea{min-height:120px;resize:vertical;font-family:monospace}.admin-modal .form-group .checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.admin-modal .form-group .checkbox-label input{width:auto}.admin-modal .form-group input.error,.admin-modal .form-group select.error,.admin-modal .form-group textarea.error{border-color:var(--error);box-shadow:0 0 0 2px #d134381a}.admin-modal .modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.admin-form-row{display:flex;gap:16px}.admin-form-row .form-group{flex:1}.form-help{display:block;font-size:12px;color:var(--gray-600);margin-top:4px}.form-error{display:block;font-size:12px;color:var(--error);margin-top:4px}.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:12px;font-weight:500;white-space:nowrap}.badge-active{background:#dff6dd;color:var(--success)}.badge-inactive{background:var(--gray-100);color:var(--gray-600)}.badge-pending{background:#fff4ce;color:#986f0b}.badge-suspended{background:#fde7e9;color:var(--error)}.badge-published{background:#dff6dd;color:var(--success)}.badge-draft{background:#fff4ce;color:#986f0b}.badge-archived{background:var(--gray-200);color:var(--gray-600)}.badge-role-admin{background:#ede9fe;color:#6d28d9}.badge-role-instructor{background:#dbeafe;color:#1d4ed8}.badge-role-student{background:#dcfce7;color:#166534}.badge-role-ta{background:#fef3c7;color:#92400e}.health-indicator{display:inline-block;width:10px;height:10px;border-radius:50%;margin-right:8px}.health-indicator.ok{background:var(--success)}.health-indicator.error{background:var(--error)}.health-indicator.degraded{background:#f5a623}.admin-error{background:#fde7e9;color:var(--error);padding:12px 16px;border-radius:6px;font-size:14px}.admin-success{background:#dff6dd;color:var(--success);padding:12px 16px;border-radius:6px;font-size:14px}.admin-warning{background:#fff4ce;color:#986f0b;padding:12px 16px;border-radius:6px;font-size:14px}.admin-info{background:#e6f4ff;color:#1d4ed8;padding:12px 16px;border-radius:6px;font-size:14px}.admin-section{background:#fff;border-radius:8px;padding:24px;box-shadow:0 1px 3px #0000001a}.admin-section h2{font-size:18px;color:var(--gray-800);margin-bottom:16px}.admin-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.admin-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:20px;transition:box-shadow .2s}.admin-card:hover{box-shadow:0 4px 12px #0000001a}.admin-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.admin-card-header h3{margin:0;font-size:16px;color:var(--gray-800)}.admin-card-body{font-size:14px;color:var(--gray-600);margin-bottom:16px}.admin-card-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--gray-600);margin-bottom:16px}.admin-card-footer{display:flex;gap:8px;border-top:1px solid var(--gray-200);padding-top:16px}.admin-detail-card{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:24px;margin-bottom:24px;box-shadow:0 1px 3px #0000001a}.admin-detail-card h2{margin:0 0 16px;font-size:18px;color:var(--gray-800)}.admin-detail-grid{display:grid;grid-template-columns:160px 1fr;gap:12px 16px;font-size:14px}.admin-detail-label{font-weight:500;color:var(--gray-600)}.admin-detail-value{color:var(--gray-800)}.admin-settings-form .form-group{margin-bottom:16px}.admin-settings-form .form-group label{display:block;font-size:13px;font-weight:500;color:var(--gray-800);margin-bottom:4px}.admin-settings-form .form-group input,.admin-settings-form .form-group select{width:100%;max-width:400px;padding:8px 12px;border:1px solid var(--gray-300);border-radius:6px;font-size:14px;box-sizing:border-box}.admin-settings-form .form-group input:focus,.admin-settings-form .form-group select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #0078d41a}.admin-settings-form .form-group .checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;cursor:pointer}.admin-settings-form .form-group .checkbox-label input{width:auto}.admin-settings-form .help-text{display:block;font-size:12px;color:var(--gray-600);margin-top:4px}.loading{display:flex;justify-content:center;align-items:center;height:200px;color:var(--gray-600)}.admin-empty-state{text-align:center;padding:48px 24px;background:#fff;border:1px solid var(--gray-200);border-radius:8px}.admin-empty-state h2{margin-bottom:8px;color:var(--gray-600)}.admin-empty-state p{margin-bottom:16px;color:var(--gray-600);font-size:14px}.template-builder{display:flex;gap:24px;align-items:flex-start}.builder-left{flex:1;min-width:0}.builder-right{flex:0 0 380px}.builder-panel{background:#fff;border:1px solid var(--gray-200);border-radius:8px;padding:20px}.module-rename-input{flex:1;padding:4px 8px;border:1px solid var(--primary);border-radius:4px;font-size:16px;font-weight:600}.module-item-count{font-size:12px;font-weight:400;color:var(--gray-500);margin-left:8px}.form-actions{display:flex;gap:8px;margin-top:12px}.picker-controls{display:flex;gap:8px;margin-bottom:12px}.picker-search{flex:1;padding:8px 12px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px}.picker-search:focus{outline:none;border-color:var(--primary)}.picker-filter{padding:8px 12px;border:1px solid var(--gray-300);border-radius:4px;font-size:14px;background:#fff}.picker-list{max-height:500px;overflow-y:auto;border:1px solid var(--gray-200);border-radius:4px;margin-bottom:12px}.picker-row{display:flex;align-items:center;padding:8px 12px;border-bottom:1px solid var(--gray-100)}.picker-row:last-child{border-bottom:none}.picker-row:hover{background:var(--gray-50, #f9fafb)}.picker-row-disabled{opacity:.5;background:var(--gray-50, #f9fafb)}.picker-row-selected{background:#0078d40f}.picker-label{display:flex;align-items:center;gap:8px;flex:1;cursor:pointer;font-size:14px}.picker-item-title{flex:1}.picker-add-controls{display:flex;gap:8px;align-items:center}.picker-add-controls select{flex:1;padding:6px 10px;border:1px solid var(--gray-300);border-radius:4px;font-size:13px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:20px}.btn-icon-danger:hover:not(:disabled){background:#fef2f2;color:#dc2626;border-color:#dc2626}@media (max-width: 768px){.template-builder{flex-direction:column}.builder-right{flex:1}}@media (max-width: 768px){.admin-layout{flex-direction:column}.admin-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--gray-200);padding:12px 0}.admin-sidebar-nav{flex-direction:row;overflow-x:auto;padding:0 12px;gap:4px}.admin-nav-link{padding:8px 14px;white-space:nowrap;border-radius:4px}.admin-nav-divider{width:1px;height:20px;margin:0 4px}.admin-content{padding:16px}.admin-template-builder{flex-direction:column}.admin-builder-panel.narrow{flex:1}.admin-form-row{flex-direction:column;gap:0}.admin-page .page-header{flex-direction:column;align-items:flex-start;gap:12px}.admin-detail-grid{grid-template-columns:1fr}.admin-toolbar{flex-direction:column;align-items:stretch}.admin-toolbar input[type=text],.admin-toolbar input[type=search]{min-width:auto}.admin-card-grid{grid-template-columns:1fr}.admin-stats-grid{grid-template-columns:repeat(2,1fr)}}*{box-sizing:border-box;margin:0;padding:0}:root{--primary: #0078d4;--primary-dark: #005a9e;--success: #107c10;--error: #d13438;--warning: #ffb900;--gray-100: #f5f5f5;--gray-200: #e0e0e0;--gray-300: #c0c0c0;--gray-600: #666666;--gray-800: #333333}body{font-family:Segoe UI,-apple-system,BlinkMacSystemFont,sans-serif;background-color:var(--gray-100);color:var(--gray-800);line-height:1.5}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer}input,button{font-size:14px}
