@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";:root{--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#111827b3;--bg-glass:#ffffff0a;--bg-glass-hover:#ffffff14;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#6366f1;--accent-hover:#818cf8;--accent-glow:#6366f14d;--accent-soft:#6366f11a;--success:#10b981;--warning:#f59e0b;--error:#ef4444;--error-soft:#ef44441a;--border:#ffffff14;--border-focus:#6366f180;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 30px var(--accent-glow);--transition:all .2s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;line-height:1.6}.auth-page{background:radial-gradient(ellipse at 20% 50%, #6366f114 0%, transparent 50%), radial-gradient(ellipse at 80% 20%, #10b9810d 0%, transparent 50%), var(--bg-primary);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.auth-container{width:100%;max-width:440px;animation:.5s cubic-bezier(.4,0,.2,1) slideUp}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.auth-brand{text-align:center;margin-bottom:2rem}.brand-logo{color:var(--text-primary);letter-spacing:-.5px;font-size:2rem;font-weight:700}.brand-accent{color:var(--accent)}.brand-tagline{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.auth-form{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:2rem}.form-header{margin-bottom:1.5rem}.form-header h2{color:var(--text-primary);font-size:1.5rem;font-weight:600}.form-header p{color:var(--text-secondary);margin-top:.25rem;font-size:.875rem}.form-group{margin-bottom:1.25rem}.form-group label{color:var(--text-secondary);margin-bottom:.375rem;font-size:.8125rem;font-weight:500;display:block}.form-group input{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-size:.9375rem;font-family:var(--font-family);transition:var(--transition);outline:none;padding:.75rem 1rem}.form-group input::placeholder{color:var(--text-muted)}.form-group input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-soft);background:var(--bg-glass-hover)}.form-group input:disabled{opacity:.5;cursor:not-allowed}.form-group small{color:var(--text-muted);margin-top:.25rem;font-size:.75rem;display:block}.form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.field-error{color:var(--error);margin-top:.25rem;font-size:.75rem;display:block}.form-error{background:var(--error-soft);border-radius:var(--radius-sm);color:var(--error);border:1px solid #ef44444d;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.875rem}.form-success{border-radius:var(--radius-sm);color:var(--success);background:#10b9811a;border:1px solid #10b9814d;margin-bottom:1.25rem;padding:.75rem 1rem;font-size:.875rem}.form-actions{margin-top:1.5rem}.btn{font-size:.9375rem;font-weight:500;font-family:var(--font-family);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;line-height:1.4;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-outline{border:1px solid var(--border);color:var(--text-secondary);background:0 0}.btn-outline:hover:not(:disabled){border-color:var(--text-muted);color:var(--text-primary);background:var(--bg-glass)}.btn-danger{background:var(--error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px);box-shadow:0 0 15px #ef444466}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px);box-shadow:0 0 15px #10b98166}.btn-sso{background:var(--bg-glass);border:1px solid var(--border);width:100%;color:var(--text-secondary);gap:.75rem}.btn-sso:hover{background:var(--bg-glass-hover);border-color:var(--text-muted);color:var(--text-primary)}.form-divider{align-items:center;margin:1.25rem 0;display:flex}.form-divider:before,.form-divider:after{content:"";background:var(--border);flex:1;height:1px}.form-divider span{color:var(--text-muted);padding:0 1rem;font-size:.8125rem}.form-footer{text-align:center;color:var(--text-muted);margin-top:1.5rem;font-size:.875rem}.link-btn{color:var(--accent);cursor:pointer;font-size:.875rem;font-family:var(--font-family);transition:var(--transition);background:0 0;border:none;padding:0}.link-btn:hover{color:var(--accent-hover);text-decoration:underline}.separator{margin:0 .5rem}.page-container{max-width:1200px;margin:0 auto;padding:2rem}.page-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;display:flex}.page-header h1{font-size:1.75rem;font-weight:600}.profile-content{gap:2rem;display:grid}.profile-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);align-items:center;gap:1.5rem;padding:1.5rem 2rem;display:flex}.profile-avatar img,.avatar-placeholder{object-fit:cover;border-radius:50%;width:72px;height:72px}.avatar-placeholder{background:var(--accent-soft);color:var(--accent);justify-content:center;align-items:center;font-size:1.5rem;font-weight:600;display:flex}.profile-info h2{font-size:1.25rem;font-weight:600}.profile-email{color:var(--text-secondary);font-size:.875rem}.profile-role{background:var(--accent-soft);color:var(--accent);border-radius:9999px;margin-top:.5rem;padding:.25rem .75rem;font-size:.75rem;font-weight:500;display:inline-block}.profile-form{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:center;align-items:center;animation:.2s ease-out fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-lg);flex-direction:column;animation:.3s cubic-bezier(.4,0,.2,1) slideUp;display:flex;overflow:hidden}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:1.5rem;display:flex}.modal-header h2{color:var(--text-primary);font-size:1.25rem;font-weight:600}.modal-close{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;font-size:1.25rem}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;align-items:center;gap:1rem;padding:1.5rem;display:flex}.loading-screen{min-height:100vh;color:var(--text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.access-denied{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:60vh;display:flex}.access-denied h2{color:var(--error);font-size:1.5rem}.access-denied p{color:var(--text-secondary)}.dashboard-placeholder{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;color:var(--text-secondary);padding:3rem}.app-layout{min-height:100vh}.app-header{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);z-index:100;justify-content:space-between;align-items:center;padding:.75rem 2rem;display:flex;position:sticky;top:0}.brand-sm{font-size:1.25rem}.header-nav{gap:.25rem;display:flex}.header-link{color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition);padding:.5rem 1rem;font-size:.875rem;font-weight:500;text-decoration:none}.header-link:hover,.header-link.active{color:var(--text-primary);background:var(--bg-glass)}.header-link--admin{color:var(--accent)}.header-actions{align-items:center;gap:1rem;display:flex}.header-user{color:var(--text-secondary);font-size:.875rem}.app-main{max-width:1200px;margin:0 auto;padding:2rem}.admin-layout{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.admin-sidebar{background:var(--bg-secondary);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:.75rem;padding:1.5rem;display:flex}.sidebar-brand h2{font-size:1.25rem;font-weight:700}.sidebar-badge{background:var(--accent-soft);color:var(--accent);text-transform:uppercase;letter-spacing:.05em;border-radius:9999px;padding:.15rem .5rem;font-size:.625rem;font-weight:600}.sidebar-nav{flex-direction:column;flex:1;gap:.125rem;padding:.75rem;display:flex}.sidebar-link{color:var(--text-secondary);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:.75rem;padding:.625rem .875rem;font-size:.875rem;font-weight:500;text-decoration:none;display:flex}.sidebar-link:hover{color:var(--text-primary);background:var(--bg-glass)}.sidebar-link--active{color:var(--accent);background:var(--accent-soft)}.sidebar-icon{font-size:1rem}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.75rem;padding:1rem 1.5rem;display:flex}.sidebar-user{align-items:center;gap:.75rem;display:flex}.avatar-sm{width:36px;height:36px;font-size:.75rem}.avatar-xs{width:28px;height:28px;font-size:.625rem}.sidebar-user-info{flex-direction:column;display:flex}.sidebar-user-name{color:var(--text-primary);font-size:.8125rem;font-weight:500}.sidebar-user-role{color:var(--text-muted);font-size:.6875rem}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-xs{padding:.25rem .5rem;font-size:.75rem}.admin-main{padding:2rem;overflow-y:auto}.admin-page{animation:.3s fadeIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-page-header{margin-bottom:2rem}.admin-page-header h1{font-size:1.75rem;font-weight:600}.page-subtitle{color:var(--text-muted);margin-top:.25rem;font-size:.875rem}.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2rem;display:grid}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:.25rem;padding:1.5rem;display:flex}.stat-value{color:var(--text-primary);font-size:2rem;font-weight:700}.stat-label{color:var(--text-muted);font-size:.8125rem;font-weight:500}.stat-card--health{padding:1rem}.admin-section{margin-bottom:2rem}.admin-section h2{margin-bottom:1rem;font-size:1.125rem;font-weight:600}.table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:.875rem}.data-table thead{background:var(--bg-glass)}.data-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.75rem;font-weight:500}.data-table td{border-bottom:1px solid var(--border);color:var(--text-secondary);padding:.75rem 1rem}.data-table tbody tr:hover{background:var(--bg-glass)}.data-table tbody tr:last-child td{border-bottom:none}.empty-state{text-align:center;color:var(--text-muted);padding:2rem}.mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:.8125rem}.user-cell{color:var(--text-primary);align-items:center;gap:.5rem;font-weight:500;display:flex}.badge{background:var(--accent-soft);color:var(--accent);border-radius:9999px;padding:.2rem .6rem;font-size:.6875rem;font-weight:500;display:inline-block}.badge--action{background:var(--bg-glass-hover);color:var(--text-secondary)}.status-dot{border-radius:50%;width:8px;height:8px;margin-right:.375rem;display:inline-block}.status-dot--active{background:var(--success)}.status-dot--inactive{background:var(--text-muted)}.health-panel{flex-direction:column;gap:.75rem;display:flex}.health-overall{align-items:center;gap:.5rem;font-size:.875rem;display:flex}.health-dot{border-radius:50%;width:10px;height:10px;animation:2s ease-in-out infinite pulse}.health-dot--sm{width:8px;height:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.health-services{flex-wrap:wrap;gap:.5rem;display:flex}.health-service-card{background:var(--bg-glass);border-radius:var(--radius-sm);flex:1;justify-content:space-between;align-items:center;gap:.75rem;min-width:120px;padding:.375rem .625rem;font-size:.75rem;display:flex}.health-service-header{align-items:center;gap:.375rem;display:flex}.health-service-name{color:var(--text-secondary);text-transform:capitalize}.health-response-time{color:var(--text-muted);font-family:monospace}.admin-filters{flex-wrap:wrap;gap:.75rem;margin-bottom:1.5rem;display:flex}.filter-input,.filter-select{background:var(--bg-glass);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:var(--font-family);transition:var(--transition);outline:none;padding:.625rem 1rem}.filter-input{flex:1;min-width:200px}.filter-input:focus,.filter-select:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-soft)}.filter-select option{background:var(--bg-secondary);color:var(--text-primary)}.pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem;padding-top:1rem;display:flex}.pagination-info{color:var(--text-muted);font-size:.8125rem}.roles-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;display:grid}.role-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:var(--transition);padding:1.25rem}.role-card:hover{border-color:var(--accent-soft);box-shadow:var(--shadow-md);transform:translateY(-2px)}.role-card-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.role-card-header h3{font-size:.9375rem;font-weight:600}.role-slug{color:var(--text-muted);background:var(--bg-glass);border-radius:var(--radius-sm);padding:.15rem .5rem;font-family:monospace;font-size:.6875rem}.role-desc{color:var(--text-secondary);font-size:.8125rem;line-height:1.5}.settings-form{max-width:720px}.settings-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.5rem}.settings-section h3{border-bottom:1px solid var(--border);margin-bottom:1.25rem;padding-bottom:.75rem;font-size:1rem;font-weight:600}.settings-form .form-row{grid-template-columns:repeat(3,1fr)}.color-input-row{align-items:center;gap:.75rem;display:flex}.color-input-row input[type=color]{cursor:pointer;border:none;width:40px;height:36px;padding:0}.color-input-row span{color:var(--text-muted);font-family:monospace}.toggle-group{flex-direction:column;gap:.75rem;display:flex}.toggle-row{cursor:pointer;color:var(--text-secondary);align-items:center;gap:.75rem;font-size:.875rem;display:flex}.toggle-row input[type=checkbox]{appearance:none;background:var(--bg-glass);border:1px solid var(--border);cursor:pointer;width:36px;height:20px;transition:var(--transition);border-radius:9999px;position:relative}.toggle-row input[type=checkbox]:after{content:"";background:var(--text-muted);width:14px;height:14px;transition:var(--transition);border-radius:50%;position:absolute;top:2px;left:2px}.toggle-row input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent)}.toggle-row input[type=checkbox]:checked:after{background:#fff;left:18px}.course-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;display:grid}.course-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);overflow:hidden}.course-card:hover{border-color:var(--accent-soft);box-shadow:var(--shadow-lg);transform:translateY(-3px)}.course-card--compact{overflow:visible}.course-card-thumbnail{background:var(--bg-glass);height:160px;position:relative;overflow:hidden}.course-card-thumbnail img{object-fit:cover;width:100%;height:100%}.course-card-placeholder{background:linear-gradient(135deg, var(--accent-soft), #6366f10d);height:100%;color:var(--accent);letter-spacing:.1em;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.course-featured-badge{background:var(--accent);color:#fff;border-radius:var(--radius-sm);padding:.2rem .5rem;font-size:.6875rem;font-weight:600;position:absolute;top:.5rem;right:.5rem}.course-card-body{padding:1rem}.course-card-meta{align-items:center;gap:.5rem;margin-bottom:.5rem;display:flex}.course-difficulty{text-transform:uppercase;letter-spacing:.05em;font-size:.6875rem;font-weight:600}.course-duration{color:var(--text-muted);font-size:.75rem}.course-card-title{color:var(--text-primary);margin-bottom:.375rem;font-size:1rem;font-weight:600;line-height:1.4}.course-card-desc{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.8125rem;display:-webkit-box;overflow:hidden}.course-card-footer{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.5rem;font-size:.75rem;display:flex}.course-category{font-weight:500}.course-enrollments{font-variant-numeric:tabular-nums}.course-detail-header{gap:2rem;margin-bottom:2rem;display:flex}.course-detail-thumbnail{border-radius:var(--radius-md);object-fit:cover;flex-shrink:0;width:320px;height:200px}.course-detail-info{flex:1}.course-detail-info h1{margin:.5rem 0;font-size:1.75rem;font-weight:700}.course-detail-desc{color:var(--text-secondary);margin-bottom:1rem;font-size:.9375rem;line-height:1.7}.course-detail-stats{color:var(--text-muted);flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;font-size:.875rem;display:flex}.course-detail-actions{gap:.75rem;display:flex}.course-detail-actions .btn-primary{width:auto}.course-content-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:1.5rem;padding:1.5rem}.course-content-list h2{margin-bottom:1rem;font-size:1.125rem}.content-items{flex-direction:column;gap:.5rem;display:flex}.content-item{background:var(--bg-glass);border-radius:var(--radius-sm);align-items:center;gap:.75rem;padding:.75rem;display:flex}.content-item-num{background:var(--accent-soft);width:28px;height:28px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:600;display:flex}.content-item-info h4{color:var(--text-primary);font-size:.875rem;font-weight:500}.content-item-meta{color:var(--text-muted);font-size:.75rem}.course-tags{flex-wrap:wrap;gap:.5rem;display:flex}.progress-bar-container{align-items:center;gap:.75rem;width:100%;display:flex}.progress-bar-track{background:var(--bg-glass);border-radius:9999px;flex:1;height:8px;overflow:hidden}.progress-bar--sm .progress-bar-track{height:6px}.progress-bar-fill{border-radius:9999px;height:100%;transition:width .5s}.progress-bar-label{color:var(--text-secondary);text-align:right;min-width:36px;font-size:.75rem;font-weight:600}.enrollment-list{flex-direction:column;gap:.75rem;display:flex}.enrollment-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.enrollment-card:hover{border-color:var(--accent-soft);background:var(--bg-glass-hover)}.enrollment-card--completed{opacity:.7;cursor:default}.enrollment-card-info{flex-direction:column;flex:1;gap:.5rem;display:flex}.enrollment-card-info h3{font-size:.9375rem;font-weight:600}.learn-header{margin-bottom:2rem}.learn-header h1{margin-bottom:.75rem;font-size:1.5rem}.learn-content{flex-direction:column;gap:.5rem;display:flex}.learn-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);transition:var(--transition);align-items:center;gap:.75rem;padding:1rem;display:flex}.learn-item--completed{opacity:.6;border-color:#10b98133}.learn-item-status{font-size:1.25rem}.learn-item-info{flex:1}.learn-item-info h3{font-size:.9375rem;font-weight:500}.learn-item-meta{color:var(--text-muted);text-transform:capitalize;font-size:.75rem}@media (width<=768px){.admin-layout{grid-template-columns:1fr}.admin-sidebar{display:none}.settings-form .form-row{grid-template-columns:1fr}}@media (width<=640px){.auth-page{padding:1rem}.auth-form{padding:1.5rem}.form-row{grid-template-columns:1fr}.profile-card{text-align:center;flex-direction:column}}
