@import "https://fonts.googleapis.com/css2?family=Public+Sans:wght@300;400;500;600;700&family=Space+Grotesk:wght@400;500;600;700&display=swap";.layout{background:var(--bg-page);min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);z-index:200;border-right:1px solid var(--sidebar-border);background:linear-gradient(#0b1f2a 0%,#0a2735 100%);flex-direction:column;height:100vh;transition:width .25s;display:flex;position:fixed;top:0;left:0;overflow:hidden;box-shadow:6px 0 30px #03101673}.sidebar.closed{width:var(--sidebar-width-collapsed)}.sidebar-brand{border-bottom:1px solid var(--sidebar-border);flex-shrink:0;align-items:center;gap:12px;min-height:68px;padding:20px 18px;text-decoration:none;display:flex}.sidebar-brand-icon{color:#fff;background:linear-gradient(135deg,#0f766e,#f97316);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.sidebar-brand-name{font-size:1rem;font-weight:700;font-family:var(--font-display);color:#fff;white-space:nowrap;line-height:1.2}.sidebar-brand-name span{color:#fff6;text-transform:uppercase;letter-spacing:.07em;font-size:.65rem;font-weight:400;display:block}.sidebar-nav{flex:1;padding:12px 8px;overflow:hidden auto}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.nav-section-label{text-transform:uppercase;letter-spacing:.1em;color:#ffffff40;white-space:nowrap;padding:12px 12px 6px;font-size:.62rem;font-weight:700}.nav-item{color:var(--sidebar-text);white-space:nowrap;border-radius:8px;align-items:center;gap:12px;margin-bottom:2px;padding:10px 12px;text-decoration:none;transition:all .18s;display:flex;position:relative}.nav-item:hover{background:var(--sidebar-hover);color:#fff;text-decoration:none}.nav-item.active{color:var(--sidebar-text-active);box-shadow:inset 3px 0 0 var(--color-accent);background:#f9731659;font-weight:600}.nav-item.active .nav-icon{color:var(--color-primary)}.nav-icon{text-align:center;width:20px;color:var(--sidebar-text);flex-shrink:0;font-size:.95rem;transition:color .18s}.nav-item:hover .nav-icon{color:var(--color-primary)}.nav-label{white-space:nowrap;font-size:.875rem;font-weight:500}.sidebar-footer{border-top:1px solid var(--sidebar-border);flex-shrink:0;padding:12px 8px}.sidebar-user{cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:background .18s;display:flex}.sidebar-user:hover{background:var(--sidebar-hover)}.sidebar-avatar{color:#fff;background:linear-gradient(135deg,#0f766e,#f97316);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:.75rem;font-weight:700;display:flex}.sidebar-user-info{overflow:hidden}.sidebar-user-name{color:#ffffffeb;white-space:nowrap;text-overflow:ellipsis;font-size:.825rem;font-weight:600;overflow:hidden}.sidebar-user-role{color:#ffffff8c;text-transform:capitalize;font-size:.7rem}.sidebar-toggle{background:var(--sidebar-bg);color:#ffffff80;cursor:pointer;z-index:201;border:1.5px solid #f9731659;border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;font-size:.65rem;transition:all .18s;display:flex;position:absolute;top:20px;right:-13px}.sidebar-toggle:hover{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.main-content{margin-left:var(--sidebar-width);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .25s;display:flex}.sidebar.closed~.main-content{margin-left:var(--sidebar-width-collapsed)}.top-header{background:var(--bg-glass);z-index:100;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;gap:16px;height:68px;padding:0 28px;display:flex;position:sticky;top:0}.header-title{font-size:1.05rem;font-weight:700;font-family:var(--font-display);color:var(--text-primary)}.header-right{align-items:center;gap:8px;display:flex}.header-icon-btn{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;font-size:.9rem;text-decoration:none;display:flex;position:relative}.header-icon-btn:hover{background:var(--color-accent-light);color:var(--color-accent);border-color:var(--color-accent);text-decoration:none}.header-divider{background:var(--border);width:1px;height:28px;margin:0 4px}.header-user{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-full);cursor:pointer;transition:background var(--transition);align-items:center;gap:10px;padding:6px 12px 6px 6px;text-decoration:none;display:flex}.header-user:hover{background:var(--border)}.header-avatar{color:#fff;background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:50%;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;font-weight:700;display:flex}.header-user-name{color:var(--text-primary);font-size:.825rem;font-weight:600}.role-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em;padding:3px 10px;font-size:.7rem;font-weight:700}.role-admin,.role-super_admin{background:var(--color-accent-light);color:#9a3412}.role-facilitator{background:var(--color-info-light);color:#0369a1}.role-student{background:var(--color-success-light);color:#065f46}.btn-logout{background:var(--color-danger-light);color:#991b1b;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);border:1px solid #fecaca;align-items:center;gap:6px;padding:7px 14px;font-size:.825rem;font-weight:600;display:flex}.btn-logout:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.content{flex:1;max-width:1500px;padding:28px}@media (width<=768px){.sidebar{width:var(--sidebar-width-collapsed)}.main-content{margin-left:var(--sidebar-width-collapsed)}.top-header{padding:0 16px}.content{padding:16px}.header-user-name,.role-badge{display:none}}.auth-wrapper{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-brand{background:linear-gradient(145deg,#0f0e17 0%,#1c1a2e 40%,#2d1b69 100%);flex-direction:column;justify-content:center;align-items:flex-start;padding:60px 56px;display:flex;position:relative;overflow:hidden}.auth-brand:before{content:"";background:radial-gradient(circle,#7c3aed40 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;top:-120px;right:-120px}.auth-brand:after{content:"";background:radial-gradient(circle,#f59e0b1f 0%,#0000 70%);border-radius:50%;width:320px;height:320px;position:absolute;bottom:-80px;left:-80px}.brand-logo{z-index:1;align-items:center;gap:14px;margin-bottom:60px;display:flex;position:relative}.brand-logo-icon{color:#fff;background:linear-gradient(135deg,#7c3aed,#a855f7);border-radius:14px;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.4rem;display:flex}.brand-logo-text{color:#fff;font-size:1.25rem;font-weight:700;line-height:1.2}.brand-logo-text span{color:#ffffff80;text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:400;display:block}.brand-heading{color:#fff;z-index:1;margin-bottom:20px;font-size:2.6rem;font-weight:800;line-height:1.2;position:relative}.brand-heading em{background:linear-gradient(135deg,#a855f7,#f59e0b);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-style:normal}.brand-subtext{color:#ffffff8c;z-index:1;max-width:360px;margin-bottom:48px;font-size:1rem;line-height:1.7;position:relative}.brand-features{z-index:1;flex-direction:column;gap:16px;display:flex;position:relative}.brand-feature{color:#fffc;align-items:center;gap:14px;font-size:.9rem;display:flex}.brand-feature-icon{color:#a855f7;background:#7c3aed33;border:1px solid #7c3aed59;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.9rem;display:flex}.auth-panel{background:#fafafa;flex-direction:column;justify-content:center;align-items:center;padding:48px 40px;display:flex;overflow-y:auto}.auth-card{width:100%;max-width:420px}.auth-header{margin-bottom:32px}.auth-header h2{color:var(--text-primary);margin-bottom:6px;font-size:1.75rem;font-weight:800}.auth-header p{color:var(--text-secondary);font-size:.9rem}.auth-form{flex-direction:column;gap:18px;display:flex}.auth-form .form-group label{color:var(--text-primary);font-size:.82rem;font-weight:600}.auth-form .form-group input{border-radius:var(--radius-md);transition:border-color var(--transition), box-shadow var(--transition);background:#fff;border:1.5px solid #e5e3f0;width:100%;padding:12px 16px;font-size:.9rem}.auth-form .form-group input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #7c3aed1a}.auth-actions{justify-content:flex-end;align-items:center;display:flex}.forgot-link{color:var(--color-primary);font-size:.82rem;font-weight:500;text-decoration:none}.forgot-link:hover{text-decoration:underline}.auth-submit{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition);border:none;justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:13px;font-size:.95rem;font-weight:700;display:flex}.auth-submit:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed59}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:24px;font-size:.875rem}.auth-footer a{color:var(--color-primary);font-weight:600;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.demo-accounts{border-top:1px solid #ebebf5;margin-top:28px;padding-top:24px}.demo-accounts-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);margin-bottom:12px;font-size:.72rem;font-weight:700}.demo-grid{flex-direction:column;gap:8px;display:flex}.demo-item{border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition);background:#f5f3ff;border:1px solid #ede9fe;grid-template-columns:90px 1fr 1fr;align-items:center;gap:8px;padding:10px 12px;display:grid}.demo-item:hover{background:#ede9fe}.demo-role{color:var(--color-primary);font-size:.78rem;font-weight:700}.demo-email,.demo-pass{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;font-family:Courier New,monospace;font-size:.75rem;overflow:hidden}@media (width<=900px){.auth-wrapper{grid-template-columns:1fr}.auth-brand{display:none}.auth-panel{min-height:100vh;padding:40px 24px}}.dashboard{max-width:1320px;margin:0 auto}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.page-title{color:var(--text-primary);margin-bottom:4px;font-size:2rem;font-weight:800}.page-subtitle{color:var(--text-secondary);font-size:.875rem}.page-actions{gap:10px;display:flex}.quiz-builder .stats-grid{margin-top:10px}.quiz-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:18px;display:flex}.quiz-course{align-items:center;gap:10px;display:flex}.quiz-course select{min-width:240px}.quiz-search input{min-width:220px}.quiz-grid{grid-template-columns:minmax(0,1.2fr) minmax(0,1fr);align-items:start;gap:20px;display:grid}.quiz-list{flex-direction:column;gap:14px;display:flex}.quiz-list-header{justify-content:space-between;align-items:center;gap:12px;display:flex}.quiz-tabs{flex-wrap:wrap;gap:8px;display:flex}.quiz-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:16px 18px;display:flex}.quiz-card-head{justify-content:space-between;align-items:flex-start;gap:12px;display:flex}.quiz-card h3{margin-bottom:4px;font-size:1rem;font-weight:700}.quiz-card p{color:var(--text-secondary);font-size:.85rem}.quiz-meta{flex-wrap:wrap;gap:8px;display:flex}.quiz-actions{gap:10px;display:flex}.quiz-panel{flex-direction:column;gap:16px;display:flex}.quiz-form{flex-direction:column;gap:12px;display:flex}.quiz-form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.quiz-toggle{gap:8px;display:grid}.quiz-toggle label{color:var(--text-secondary);align-items:center;gap:8px;font-size:.85rem;display:flex}.quiz-form-actions{gap:12px;display:flex}.quiz-callout{border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f766e14,#0e74901a);border:1px dashed #0f766e33;padding:18px}.quiz-callout h3{margin-bottom:6px;font-size:1rem}.quiz-callout p{color:var(--text-secondary);font-size:.85rem}@media (width<=1100px){.quiz-grid{grid-template-columns:1fr}}@media (width<=720px){.quiz-course select,.quiz-search input{min-width:100%}.quiz-course,.quiz-search{width:100%}.quiz-form-grid{grid-template-columns:1fr}}.stats-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:16px;margin-bottom:28px;display:grid}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition), transform var(--transition);align-items:flex-start;gap:16px;padding:22px;display:flex}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card.highlight{color:#fff;background:linear-gradient(135deg,#0f766e 0%,#14b8a6 100%);border-color:#0000}.stat-card.highlight .stat-info p{color:#ffffffb3}.stat-card.gold{color:#fff;background:linear-gradient(135deg,#f97316 0%,#fb923c 100%);border-color:#0000}.stat-card.gold .stat-info p{color:#ffffffbf}.stat-icon-wrap{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:1.25rem;display:flex}.stat-icon-wrap.purple{background:var(--color-primary-light);color:var(--color-primary)}.stat-icon-wrap.teal{color:#0f766e;background:#ccfbf1}.stat-icon-wrap.blue{color:#0284c7;background:#e0f2fe}.stat-icon-wrap.amber{color:#d97706;background:#fef3c7}.stat-icon-wrap.rose{color:#be123c;background:#ffe4e6}.stat-icon-wrap.white{color:#fff;background:#fff3}.stat-info h3{color:inherit;margin-bottom:4px;font-size:1.65rem;font-weight:800;line-height:1}.stat-info p{color:var(--text-secondary);font-size:.8rem;font-weight:500}.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(380px,1fr));gap:20px;display:grid}.dashboard-section{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm);overflow:hidden}.section-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 20px;display:flex}.section-header h3{color:var(--text-primary);align-items:center;gap:8px;font-size:.95rem;font-weight:700;display:flex}.section-header h3 i{color:var(--color-primary)}.section-body{padding:6px 0}.data-table{border-collapse:collapse;width:100%}.data-table thead{background:var(--bg-muted)}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);padding:10px 16px;font-size:.72rem;font-weight:700}.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.875rem}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr:hover{background:var(--bg-muted)}.assessment-panel{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:24px;padding:18px}.assessment-tools{flex-wrap:wrap;justify-content:space-between;gap:16px;margin-bottom:18px;display:flex}.assessment-filters{flex:1;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.assessment-actions{align-items:center;gap:12px;display:flex}.assessment-table td,.assessment-table th{vertical-align:middle}.assessment-student{justify-content:space-between;align-items:center;gap:12px;display:flex}.assessment-name{color:var(--text-primary);font-weight:700}.assessment-email{color:var(--text-muted);font-size:.75rem}.score-input{border:1px solid var(--border-strong);border-radius:var(--radius-md);width:92px;padding:8px 10px;font-size:.85rem}.assessment-total{color:var(--text-primary);font-weight:700}@media (width<=900px){.assessment-actions{justify-content:flex-start;width:100%}.score-input{width:80px}}.course-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px;display:grid}.course-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border);transition:box-shadow var(--transition), transform var(--transition);cursor:pointer;overflow:hidden}.course-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}.course-card-link{color:inherit;text-decoration:none;display:block}.course-thumbnail{object-fit:cover;width:100%;height:160px}.course-placeholder{background:linear-gradient(135deg, var(--color-primary-light) 0%, #ddd6fe 100%);width:100%;height:160px;color:var(--color-primary);justify-content:center;align-items:center;font-size:2.5rem;display:flex}.course-body{padding:18px}.course-card h4{color:var(--text-primary);margin-bottom:6px;font-size:.95rem;font-weight:700;line-height:1.4}.course-description{color:var(--text-secondary);-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-bottom:12px;font-size:.82rem;line-height:1.5;display:-webkit-box;overflow:hidden}.course-meta{border-top:1px solid var(--border);justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;display:flex}.course-price{color:var(--color-primary);font-size:1rem;font-weight:800}.course-instructor{color:var(--text-muted);align-items:center;gap:4px;font-size:.78rem;display:flex}.content-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.content-header h2{color:var(--text-primary);font-size:1.15rem;font-weight:700}.list-item{border-bottom:1px solid var(--border);transition:background var(--transition);align-items:center;gap:14px;padding:14px 20px;display:flex}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--bg-muted)}.list-item-avatar{background:var(--color-primary-light);width:40px;height:40px;color:var(--color-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.9rem;font-weight:700;display:flex}.list-item-content{flex:1;min-width:0}.list-item-title{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.875rem;font-weight:600;overflow:hidden}.list-item-sub{color:var(--text-muted);margin-top:2px;font-size:.78rem}@media (width<=1024px){.dashboard-grid{grid-template-columns:1fr}}@media (width<=768px){.stats-grid{grid-template-columns:repeat(2,1fr)}.course-grid{grid-template-columns:1fr}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}}.checkout-page .page-header{background:0 0;margin-bottom:20px}.checkout-grid{grid-template-columns:minmax(280px,1fr) minmax(320px,1.1fr);gap:24px;display:grid}.checkout-summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.checkout-summary h3{margin-bottom:6px;font-size:1.25rem}.checkout-price{color:var(--color-primary);margin-bottom:8px;font-size:2rem;font-weight:800}.checkout-description{color:var(--text-secondary);font-size:.9rem}.checkout-features{gap:10px;margin-top:18px;display:grid}.checkout-features div{border-radius:var(--radius-md);background:var(--bg-muted);color:var(--text-secondary);align-items:center;gap:10px;padding:10px 12px;font-size:.85rem;display:flex}.checkout-panel{gap:16px;display:grid}.payment-form{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.payment-methods{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.payment-option{border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:all var(--transition);color:var(--text-secondary);background:#fff;align-items:center;gap:8px;padding:10px 12px;font-size:.78rem;font-weight:600;display:flex}.payment-option input{margin:0}.payment-option.selected{border-color:var(--color-primary);color:var(--text-primary);box-shadow:var(--shadow-glow)}.payment-placeholder{border:1px dashed var(--border-strong);border-radius:var(--radius-lg);background:linear-gradient(135deg,#0f766e14,#f9731614);padding:20px}.placeholder-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px;display:flex}.placeholder-header h4{margin-bottom:4px}.placeholder-header p{color:var(--text-secondary);font-size:.82rem}.placeholder-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.payment-callback{justify-content:center;display:flex}.payment-result{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;width:100%;max-width:560px;box-shadow:var(--shadow-md);padding:32px}.payment-result h2{margin-bottom:8px}.payment-result p{color:var(--text-secondary)}.result-icon{background:var(--bg-muted);border-radius:50%;place-items:center;width:64px;height:64px;margin:0 auto 16px;font-size:1.8rem;display:grid}.payment-result.success .result-icon{background:var(--color-success-light);color:var(--color-success)}.payment-result.failed .result-icon{background:var(--color-danger-light);color:var(--color-danger)}.payment-result.processing .result-icon{background:var(--color-info-light);color:var(--color-info)}.payment-result.unknown .result-icon{background:var(--color-warning-light);color:var(--color-warning)}.result-actions{flex-wrap:wrap;justify-content:center;gap:10px;margin-top:18px;display:flex}.course-detail{gap:20px;display:grid}.course-detail-header{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.course-detail-header h1{margin-bottom:6px;font-size:2rem}.course-detail-grid{grid-template-columns:minmax(280px,2fr) minmax(260px,1fr);align-items:start;gap:22px;display:grid}.course-detail-main h2{margin:16px 0 10px}.course-detail-main p{color:var(--text-secondary)}.course-detail-sidebar{position:sticky;top:88px}.course-price-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px}.course-price-card .price{color:var(--color-primary);font-size:2rem;font-weight:800}.course-features{color:var(--text-secondary);gap:8px;margin-top:16px;font-size:.85rem;display:grid}.module-list{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);margin-top:12px;padding:16px}.module-list ul{gap:8px;margin-top:10px;list-style:none;display:grid}.lesson-icon{background:var(--bg-muted);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;margin-right:8px;display:inline-flex}.lesson-duration{color:var(--text-muted);font-size:.8rem}.enrollments-list{gap:16px;display:grid}.enrollment-card-link{color:inherit;text-decoration:none}.enrollment-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform var(--transition), box-shadow var(--transition);justify-content:space-between;gap:16px;padding:16px;display:flex}.enrollment-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.enrollment-card-content{gap:16px;display:flex}.enrollment-thumbnail{object-fit:cover;border-radius:var(--radius-md);width:110px;height:80px}.enrollment-info h4{margin-bottom:4px}.enrollment-instructor{color:var(--text-secondary);font-size:.82rem}.enrollment-progress{margin-top:10px}.enrollment-meta{color:var(--text-muted);align-items:center;gap:10px;margin-top:8px;font-size:.78rem;display:flex}.enrollment-action{align-items:center;display:flex}.continue-btn{color:var(--color-primary);font-weight:700}.course-content-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:16px;display:flex}.progress-bar-large{background:var(--border);border-radius:var(--radius-full);width:220px;height:8px;margin-bottom:6px;overflow:hidden}.progress-fill-large{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));height:100%}.progress-text-large{color:var(--text-secondary);font-size:.8rem}.modules-list{gap:16px;display:grid}.module-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:18px}.module-number{background:var(--color-primary-light);width:26px;height:26px;color:var(--color-primary);border-radius:50%;justify-content:center;align-items:center;margin-right:8px;font-size:.78rem;display:inline-flex}.module-description{color:var(--text-secondary);margin-top:6px;font-size:.85rem}.module-lessons{gap:10px;margin-top:14px;display:grid}.lesson-card{border-radius:var(--radius-md);border:1px solid var(--border);cursor:pointer;transition:all var(--transition);background:#fff;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.lesson-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.lesson-card.completed{background:var(--color-success-light);border-color:#86efac}.lesson-info h4{margin-bottom:4px}.lesson-status{justify-content:flex-end;min-width:110px;display:flex}.lesson-viewer{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.lesson-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:20px;display:flex}.lesson-content-area{background:var(--bg-muted);border-radius:var(--radius-lg);border:1px solid var(--border);padding:18px}.lesson-video{border-radius:var(--radius-md);width:100%}.lesson-text-content{color:var(--text-secondary);line-height:1.7}.pdf-controls{justify-content:center;align-items:center;gap:10px;margin-top:12px;display:flex}.lesson-footer{justify-content:flex-end;gap:10px;margin-top:16px;display:flex}.quiz-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:24px}.quiz-header-bar{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.quiz-timer{background:var(--bg-muted);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-secondary);align-items:center;gap:6px;padding:6px 12px;font-weight:600;display:inline-flex}.quiz-timer.timer-warning{background:var(--color-warning-light);color:#92400e;border-color:#fcd34d}.quiz-progress{color:var(--text-secondary);justify-content:space-between;margin-bottom:8px;font-size:.85rem;display:flex}.quiz-question{margin-top:18px}.quiz-options{gap:10px;margin-top:12px;display:grid}.quiz-option{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);background:#fff;grid-template-columns:auto auto 1fr;align-items:center;gap:10px;padding:12px;display:grid}.quiz-option.selected{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.option-label{background:var(--bg-muted);width:28px;height:28px;color:var(--text-secondary);border-radius:50%;place-items:center;font-weight:700;display:grid}.quiz-option.selected .option-label{background:var(--color-primary-light);color:var(--color-primary)}.option-text{color:var(--text-secondary)}.quiz-navigation{justify-content:space-between;gap:10px;margin-top:18px;display:flex}.quiz-question-nav{flex-wrap:wrap;gap:8px;margin-top:16px;display:flex}.question-dot{border:1px solid var(--border);cursor:pointer;background:#fff;border-radius:50%;width:34px;height:34px;font-weight:600}.question-dot.answered{border-color:var(--color-primary);color:var(--color-primary)}.question-dot.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.quiz-results-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);text-align:center;padding:28px}.quiz-score-summary{flex-direction:column;align-items:center;gap:10px;margin:16px 0;display:flex}.score-circle{background:var(--color-primary-light);border-radius:50%;place-items:center;width:120px;height:120px;display:grid}.score-value{color:var(--color-primary);font-size:1.6rem;font-weight:800}.score-badge{font-size:.75rem}.user-stats{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:20px;display:grid}.users-toolbar{flex-wrap:wrap;justify-content:space-between;gap:12px;margin-bottom:16px;display:flex}.users-search{border:1px solid var(--border);border-radius:var(--radius-md);background:#fff;flex:1;align-items:center;gap:10px;min-width:260px;padding:10px 12px;display:flex}.users-search i{color:var(--text-muted)}.users-search input{background:0 0;border:none;outline:none;flex:1;font-size:.9rem}.users-filters{align-items:center;gap:10px;display:flex}.users-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.user-cell{align-items:center;gap:12px;display:flex}.user-avatar{background:var(--color-primary-light);width:36px;height:36px;color:var(--color-primary);border-radius:50%;place-items:center;font-size:.85rem;font-weight:700;display:grid}.user-name{font-weight:600}.user-email{color:var(--text-secondary);font-size:.8rem}.payment-stats{grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:20px;display:grid}.payments-toolbar{flex-wrap:wrap;justify-content:space-between;gap:12px;margin-bottom:16px;display:flex}.payments-filters{flex-wrap:wrap;gap:10px;display:flex}.payments-actions{align-items:center;gap:10px;display:flex}.payments-table{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.payment-id{gap:4px;display:grid}.payment-ref{font-weight:600}.payment-method{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.payment-amount{color:var(--color-primary);font-weight:700}@media (width<=768px){.payments-filters select,.payments-actions button{flex:1}.users-filters{width:100%}.users-filters select,.users-filters button{flex:1}}@media (width<=1024px){.checkout-grid,.course-detail-grid{grid-template-columns:1fr}.course-detail-sidebar{position:static}.enrollment-card{flex-direction:column;align-items:flex-start}}@media (width<=768px){.payment-methods,.placeholder-row{grid-template-columns:1fr}.lesson-card{flex-direction:column;align-items:flex-start}.lesson-status{justify-content:flex-start;width:100%}}.btn{border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:.875rem;font-weight:600;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 10px 20px #0f766e33}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border);background:#fff}.btn-secondary:hover:not(:disabled){background:var(--bg-muted);color:var(--text-primary)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-warning{background:var(--color-warning);color:#fff}.btn-warning:hover:not(:disabled){background:#d97706}.btn-info{background:var(--color-info);color:#fff}.btn-outline{color:var(--color-primary);border:1.5px solid var(--color-primary);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-primary-light)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover:not(:disabled){background:var(--bg-muted);color:var(--text-primary)}.btn-sm{border-radius:var(--radius-sm);padding:6px 14px;font-size:.8rem}.btn-lg{padding:14px 28px;font-size:1rem}.btn-block{justify-content:center;width:100%}.btn-icon{justify-content:center;width:36px;height:36px;padding:8px}.alert{border-radius:var(--radius-md);align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 16px;font-size:.875rem;font-weight:500;display:flex}.alert-error{background:var(--color-danger-light);color:#991b1b;border:1px solid #fca5a5}.alert-success{background:var(--color-success-light);color:#065f46;border:1px solid #6ee7b7}.alert-warning{background:var(--color-warning-light);color:#92400e;border:1px solid #fcd34d}.alert-info{background:var(--color-info-light);color:#075985;border:1px solid #7dd3fc}.badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:4px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-admin,.badge-super_admin{color:#5b21b6;background:#ede9fe}.badge-facilitator{background:var(--color-info-light);color:#0369a1}.badge-student,.badge-active,.badge-success,.badge-completed{background:var(--color-success-light);color:#065f46}.badge-warning,.badge-pending{background:var(--color-warning-light);color:#92400e}.badge-danger,.badge-revoked,.badge-failed,.badge-suspended{background:var(--color-danger-light);color:#991b1b}.badge-beginner{color:#065f46;background:#d1fae5}.badge-intermediate{color:#92400e;background:#fef3c7}.badge-advanced{color:#5b21b6;background:#ede9fe}.badge-primary{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-info{background:var(--color-info-light);color:#075985}.badge-secondary{color:#374151;background:#e5e7eb}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-primary);font-size:.825rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition), box-shadow var(--transition);background:#fff;padding:10px 14px;font-size:.9rem}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--color-primary);box-shadow:var(--shadow-glow);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border);padding:24px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0f0e178c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border-radius:var(--radius-xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:32px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.modal-header h3{color:var(--text-primary);font-size:1.15rem;font-weight:700}.modal-close{background:var(--bg-muted);border-radius:var(--radius-sm);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);transition:background var(--transition);border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--border)}.modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.loading{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.loading i{color:var(--color-primary);font-size:2rem;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:48px 20px}.empty-state i{color:var(--border-strong);margin-bottom:12px;font-size:3rem;display:block}.empty-state p{margin-bottom:16px;font-size:.9rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-primary{color:var(--text-primary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-warning{color:var(--color-warning)}.font-bold{font-weight:700}.font-semibold{font-weight:600}.filters{flex-wrap:wrap;gap:10px;margin-bottom:20px;display:flex}.filters input,.filters select{border:1.5px solid var(--border-strong);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition);background:#fff;padding:9px 14px;font-size:.875rem}.filters input:focus,.filters select:focus{border-color:var(--color-primary);outline:none}.filters input{flex:1;min-width:200px}.actions{flex-wrap:wrap;gap:6px;display:flex}.pagination{justify-content:center;align-items:center;gap:10px;margin-top:24px;display:flex}.pagination span{color:var(--text-secondary);font-size:.875rem}.progress-bar{background:var(--border);border-radius:var(--radius-full);width:100%;height:6px;margin:10px 0 6px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-full);height:100%;transition:width .4s}.progress-text{color:var(--text-secondary);font-size:.78rem;font-weight:600}@media (width<=768px){.modal{border-radius:var(--radius-lg);padding:24px}.filters{flex-direction:column}.filters input{min-width:100%}}:root{--color-primary:#0f766e;--color-primary-dark:#0a5c56;--color-primary-light:#ccfbf1;--color-primary-glow:#0f766e2e;--color-accent:#f97316;--color-accent-light:#ffedd5;--color-gold:#d97706;--color-gold-light:#fef3c7;--color-success:#16a34a;--color-success-light:#dcfce7;--color-danger:#dc2626;--color-danger-light:#fee2e2;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-info:#0284c7;--color-info-light:#e0f2fe;--sidebar-bg:#0b1f2a;--sidebar-hover:#112c3a;--sidebar-active:#f9731638;--sidebar-text:#ffffffa6;--sidebar-text-active:#fff;--sidebar-border:#ffffff14;--sidebar-width:272px;--sidebar-width-collapsed:72px;--bg-page:#f4f1ec;--bg-card:#fff;--bg-muted:#f8f6f2;--bg-glass:#ffffffb3;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--border:#e2ddd4;--border-strong:#d6cfc4;--shadow-sm:0 1px 3px #0f172a14, 0 1px 2px #0f172a0d;--shadow-md:0 12px 26px #0f172a1f;--shadow-lg:0 24px 56px #0f172a2e;--shadow-glow:0 0 0 3px var(--color-primary-glow);--radius-sm:8px;--radius-md:12px;--radius-lg:18px;--radius-xl:28px;--radius-full:9999px;--font-body:"Public Sans", system-ui, sans-serif;--font-display:"Space Grotesk", "Public Sans", system-ui, sans-serif;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-body);background:var(--bg-page);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6;position:relative;overflow-x:hidden}body:before{content:"";pointer-events:none;z-index:0;background:radial-gradient(circle at 0 0,#f9731626,#0000 45%),radial-gradient(circle at 20% 20%,#0f766e2e,#0000 55%),radial-gradient(circle at 80% 0,#0e749033,#0000 50%);position:fixed;inset:-20% 0 0}#root{z-index:1;position:relative}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit}img{max-width:100%}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);letter-spacing:-.02em}
