.course-creation-page{max-width:800px;margin:0 auto;padding:2rem}.loading-state{text-align:center;color:#666;padding:3rem;font-size:1.125rem}.page-header h1{color:#333;margin:0 0 2rem;font-size:2rem}.course-form{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px rgba(0,0,0,.1)}.error-box{background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;margin-bottom:1.5rem;padding:1rem}.error-box h3{color:#721c24;margin:0 0 .5rem;font-size:1rem}.error-box ul{color:#721c24;margin:0;padding-left:1.5rem}.error-box li{margin-bottom:.25rem}.form-group{margin-bottom:1.5rem}.form-group label{color:#333;margin-bottom:.5rem;font-weight:500;display:block}.required{color:#dc3545}.form-group textarea{border:1px solid #ddd;border-radius:6px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input[type=text]{border:1px solid #ddd;border-radius:6px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group textarea:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 3px rgba(33,150,243,.1)}.form-group input[type=text]:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 3px rgba(33,150,243,.1)}.form-group textarea{resize:vertical;min-height:120px}.form-help{color:#666;margin-top:.25rem;font-size:.875rem;display:block}.requirements-input-group{gap:.5rem;margin-bottom:.5rem;display:flex}.requirements-input-group input{flex:1}.requirements-list li{background:#f5f5f5;border-radius:6px;justify-content:space-between;align-items:center;margin-bottom:.5rem;padding:.75rem;display:flex}.requirements-list li span{color:#333;flex:1}.btn-remove{color:#fff;cursor:pointer;background:#dc3545;border:none;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;font-size:.875rem;transition:background .2s;display:flex}.btn-remove:hover{background:#c82333}.form-actions{border-top:1px solid #e0e0e0;justify-content:flex-end;gap:1rem;margin-top:2rem;padding-top:1.5rem;display:flex}.btn:hover{transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.2)}@media (max-width:768px){.course-creation-page{padding:1rem}.page-header h1{font-size:1.5rem}.course-form{padding:1.5rem}.requirements-input-group{flex-direction:column}.requirements-input-group input{width:100%}.form-actions{flex-direction:column}.form-actions .btn{width:100%}}.form-group.has-error input,.form-group.has-error textarea,.form-group.has-error select{border-color:#dc3545}.form-group.has-error input:focus,.form-group.has-error textarea:focus,.form-group.has-error select:focus{border-color:#dc3545;box-shadow:0 0 0 3px rgba(220,53,69,.1)}.field-error{color:#dc3545;margin-top:.25rem;font-size:.875rem;font-weight:500;display:block}.form-group select{cursor:pointer;background-color:#fff;border:1px solid #ddd;border-radius:6px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group select:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 3px rgba(33,150,243,.1)}.image-upload-area{text-align:center;cursor:pointer;background:#fafafa;border:2px dashed #ddd;border-radius:8px;padding:3rem 2rem;transition:all .3s}.image-upload-area:hover{background:#f0f8ff;border-color:#2196f3}.image-upload-area.dragging{background:#e3f2fd;border-color:#2196f3;transform:scale(1.02)}.upload-icon{margin-bottom:1rem;font-size:3rem}.upload-text{color:#333;margin:0 0 .5rem;font-size:1rem;font-weight:500}.upload-help{color:#666;font-size:.875rem;display:block}.image-preview-container{max-width:100%;display:inline-block;position:relative}.image-preview{border:2px solid #ddd;border-radius:8px;max-width:100%;max-height:300px;display:block}.btn-remove-image{color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:rgba(220,53,69,.9);border:none;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;font-weight:500;transition:all .2s;position:absolute;top:10px;right:10px}.btn-remove-image:hover{background:#c82333;transform:scale(1.05)}.form-row-2{grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem;display:grid}.form-group input[type=number]{border:1px solid #ddd;border-radius:6px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input[type=url]{border:1px solid #ddd;border-radius:6px;width:100%;padding:.75rem;font-family:inherit;font-size:1rem;transition:border-color .2s}.form-group input[type=number]:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 3px rgba(33,150,243,.1)}.form-group input[type=url]:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 3px rgba(33,150,243,.1)}@media (max-width:768px){.form-row-2{grid-template-columns:1fr}.image-upload-area{padding:2rem 1rem}.upload-icon{font-size:2rem}}.course-detail-page{max-width:900px;margin:0 auto;padding:2rem}.error-state p{color:#dc3545;margin-bottom:1rem;font-size:1.125rem}.back-button{color:#2196f3;cursor:pointer;background:0 0;border:none;margin-bottom:1.5rem;padding:.5rem 0;font-size:1rem;transition:color .2s}.back-button:hover{color:#1976d2;text-decoration:underline}.enrollment-status-banner{border-radius:8px;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding:1rem 1.5rem;font-weight:500;display:flex}.status-icon{font-size:1.5rem}.status-text{font-size:1rem}.status-active{color:#1976d2;background:#e3f2fd;border:2px solid #2196f3}.status-completed,.status-pending{color:#856404;background:#fff3cd;border:2px solid #ffc107}.status-approved{color:#155724;background:#d4edda;border:2px solid #28a745}.status-rejected{color:#721c24;background:#f8d7da;border:2px solid #dc3545}.course-detail-container{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.1)}.course-header{color:#fff;background:linear-gradient(135deg,#2196f3 0%,#1976d2 100%);padding:2.5rem 2rem}.course-header h1{margin:0 0 1rem;font-size:2rem;line-height:1.3}.course-meta-info{flex-wrap:wrap;gap:1rem;display:flex}.meta-badge{background:rgba(255,255,255,.2);border-radius:20px;align-items:center;gap:.5rem;padding:.5rem 1rem;font-size:.9rem;display:flex}.meta-icon{font-size:1.125rem}.course-content{padding:2rem}.course-section{margin-bottom:2rem}.course-section:last-child{margin-bottom:0}.course-section h2{color:#333;border-bottom:2px solid #e0e0e0;margin:0 0 1rem;padding-bottom:.5rem;font-size:1.5rem}.course-description{color:#666;margin:0;font-size:1.0625rem;line-height:1.8}.requirements-list{margin:0;padding:0;list-style:none}.requirements-list li{color:#333;align-items:flex-start;gap:.75rem;padding:.75rem 0;line-height:1.6;display:flex}.requirement-icon{color:#28a745;flex-shrink:0;margin-top:.125rem;font-weight:700}.enrollment-info{background:#f8f9fa;border-radius:8px;padding:1.5rem}.enrollment-details{flex-direction:column;gap:.75rem;display:flex}.detail-item{justify-content:space-between;align-items:center;padding:.5rem 0;display:flex}.detail-label{color:#666;font-weight:500}.detail-value{color:#333;font-weight:500}.course-actions{background:#f8f9fa;border-top:1px solid #e0e0e0;padding:1.5rem 2rem}.btn-large{width:100%;padding:1rem 2rem;font-size:1.125rem}.btn-success{color:#fff;background:#28a745}.modal-overlay{z-index:1000;background:rgba(0,0,0,.5);justify-content:center;align-items:center;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.modal-content{background:#fff;border-radius:12px;width:90%;max-width:500px;padding:2rem;box-shadow:0 4px 6px rgba(0,0,0,.1)}.modal-content h2{color:#333;margin-top:0;margin-bottom:1rem}.modal-content p{color:#666;margin-bottom:1rem;line-height:1.6}.modal-info{background:#f8f9fa;border-radius:6px;margin-bottom:1.5rem;padding:1rem}.modal-info p{color:#333;margin:0 0 .5rem;font-weight:500}.modal-info ul{color:#666;margin:0;padding-left:1.5rem}.modal-info li{margin-bottom:.25rem}.modal-actions{justify-content:flex-end;gap:1rem;display:flex}@media (max-width:768px){.course-detail-page{padding:1rem}.course-header{padding:2rem 1.5rem}.course-header h1{font-size:1.5rem}.course-content{padding:1.5rem}.course-section h2{font-size:1.25rem}.course-actions{padding:1.5rem}.detail-item{flex-direction:column;align-items:flex-start;gap:.25rem}.modal-content{padding:1.5rem}.modal-actions{flex-direction:column}.modal-actions .btn{width:100%}}.offline-message{color:#856404;text-align:center;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;margin-top:1rem;padding:.75rem 1rem;font-size:.9375rem}.virtualized-list{will-change:scroll-position;position:relative;overflow-x:hidden;overflow-y:auto}.virtualized-list-spacer{width:100%;position:relative}.virtualized-list-content{will-change:transform;position:absolute;top:0;left:0;right:0}.virtualized-list-item{width:100%;overflow:hidden}.virtualized-list-empty{color:var(--text-secondary,#6c757d);text-align:center;justify-content:center;align-items:center;padding:32px;display:flex}.virtualized-list{scroll-behavior:smooth}@media (min-width:1024px){.virtualized-list::-webkit-scrollbar{width:8px}.virtualized-list::-webkit-scrollbar-track{background:var(--background-alt,#f8f9fa);border-radius:4px}.virtualized-list::-webkit-scrollbar-thumb{background:var(--border,#dee2e6);border-radius:4px}.virtualized-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary,#6c757d)}}.course-list-page{background:var(--color-bg-secondary)}.course-list-container{flex-direction:column;gap:1.25rem;display:flex}.page-header{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center;padding:1.5rem}.page-header h1{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.02em;margin:0 0 4px}.subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.filters-section{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1rem 1.25rem}.search-box{max-width:480px;margin:0 auto}.search-input{border:1px solid var(--border-color);border-radius:var(--radius-full);width:100%;font-size:var(--font-size-base);font-family:var(--font-family);color:var(--text-primary);background:var(--color-bg-primary);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);padding:9px 16px}.search-input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px rgba(29,78,216,.1)}.empty-state{text-align:center;background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:4rem 2rem}.empty-icon{margin-bottom:1rem;font-size:3rem}.empty-state h2{font-size:1.25rem;font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0 0 6px}.empty-state p{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.courses-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.course-card{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;transition:border-color var(--transition-normal), box-shadow var(--transition-normal);flex-direction:column;padding:1.5rem;display:flex}.course-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md)}.course-card-header{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1rem;display:flex}.course-card-header h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--text-primary);line-height:var(--line-height-tight);flex:1;margin:0}.enrollment-badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap;flex-shrink:0;align-items:center;padding:3px 10px;display:inline-flex}.enrollment-active{background:var(--color-primary-xlight);color:var(--primary-color)}.enrollment-completed{color:#065f46;background:#d1fae5}.enrollment-pending{color:#92400e;background:#fef3c7}.enrollment-approved{color:#065f46;background:#d1fae5}.enrollment-rejected{color:#991b1b;background:#fee2e2}.course-description{color:var(--text-secondary);line-height:var(--line-height-relaxed);font-size:var(--font-size-sm);-webkit-line-clamp:3;-webkit-box-orient:vertical;flex:1;margin:0 0 1rem;display:-webkit-box;overflow:hidden}.course-meta{border-top:1px solid var(--color-border-light);gap:1rem;margin-bottom:1rem;padding-top:1rem;display:flex}.meta-item{font-size:var(--font-size-xs);color:var(--text-secondary);align-items:center;gap:6px;display:flex}.course-card-footer{margin-top:auto}.btn{border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);transition:all var(--transition-normal);border:none;justify-content:center;align-items:center;gap:6px;padding:9px 16px;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-block{width:100%}.btn-primary{background:var(--primary-color);color:#fff}.btn-secondary{background:var(--color-bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}@media (max-width:768px){.courses-grid{grid-template-columns:1fr;gap:.75rem}.course-card{padding:1.25rem}.course-card-header h3{font-size:var(--font-size-base)}}@media (max-width:480px){.course-card-header{flex-direction:column;align-items:flex-start}.enrollment-badge{align-self:flex-start}}.course-publish-page{max-width:800px;margin:0 auto;padding:2rem}.loading-state,.error-state{text-align:center;padding:3rem}.loading-state{color:#666;font-size:1.125rem}.error-state p{color:#dc3545;margin-bottom:1rem}.publish-container{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px rgba(0,0,0,.1)}.publish-header{color:#fff;text-align:center;background:linear-gradient(135deg,#2196f3 0%,#1976d2 100%);padding:2rem}.publish-header h1{margin:0 0 .5rem;font-size:2rem}.subtitle{opacity:.9;margin:0;font-size:1rem}.error-box{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb;border-radius:6px;margin:1.5rem;padding:1rem}.course-preview{border-bottom:1px solid #e0e0e0;padding:2rem}.course-preview h2{color:#333;margin:0 0 1.5rem;font-size:1.5rem}.course-detail{margin-bottom:1.5rem}.course-detail label{color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;font-size:.875rem;font-weight:600;display:block}.course-detail p{color:#333;margin:0;line-height:1.6}.requirements-list{color:#333;margin:0;padding-left:1.5rem}.requirements-list li{margin-bottom:.5rem;line-height:1.5}.status-badge{border-radius:12px;padding:.25rem .75rem;font-size:.875rem;font-weight:500;display:inline-block}.status-draft{color:#856404;background:#fff3cd}.publish-info{background:#e3f2fd;align-items:flex-start;gap:1rem;padding:1.5rem 2rem;display:flex}.info-icon{flex-shrink:0;font-size:2rem}.info-content h3{color:#1976d2;margin:0 0 .75rem;font-size:1.125rem}.info-content ul{color:#0d47a1;margin:0;padding-left:1.5rem}.info-content li{margin-bottom:.5rem;line-height:1.5}.announcement-duration{background:#f8f9fa;border-bottom:1px solid #e0e0e0;padding:2rem}.announcement-duration label{color:#333;align-items:center;gap:.5rem;margin-bottom:.5rem;font-size:1rem;font-weight:600;display:flex}.label-icon{font-size:1.25rem}.field-description{color:#666;margin:0 0 1rem;font-size:.875rem;line-height:1.5}.duration-select{cursor:pointer;background:#fff;border:2px solid #dee2e6;border-radius:6px;width:100%;padding:.75rem 1rem;font-size:1rem;transition:all .2s}.duration-select:hover:not(:disabled){border-color:#2196f3}.duration-select:focus{border-color:#2196f3;outline:none;box-shadow:0 0 0 3px rgba(33,150,243,.1)}.duration-select:disabled{cursor:not-allowed;opacity:.6;background:#e9ecef}.duration-info{color:#495057;background:#fff;border-left:4px solid #2196f3;border-radius:4px;margin:.75rem 0 0;padding:.75rem 1rem;font-size:.875rem;line-height:1.5}.publish-actions{background:#f5f5f5;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;display:flex}.btn{cursor:pointer;border:none;border-radius:6px;padding:.75rem 1.5rem;font-size:1rem;font-weight:500;transition:all .2s}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,.2)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-primary{color:#fff;background:#2196f3}.btn-primary:hover:not(:disabled){background:#1976d2}.btn-secondary{color:#fff;background:#6c757d}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-success{color:#fff;background:#28a745;padding:.875rem 2rem;font-size:1.125rem}.btn-success:hover:not(:disabled){background:#218838}@media (max-width:768px){.course-publish-page{padding:1rem}.publish-header{padding:1.5rem}.publish-header h1{font-size:1.5rem}.course-preview{padding:1.5rem}.course-preview h2{font-size:1.25rem}.publish-info{flex-direction:column;padding:1.5rem}.info-icon{font-size:1.5rem}.announcement-duration{padding:1.5rem}.publish-actions{flex-direction:column;padding:1.5rem}.publish-actions .btn{width:100%}}
