:root{--ha-primary:#a855f7;--ha-primary-dark:#7c3aed;--ha-secondary:#6366f1;--ha-accent:#22d3ee;--ha-success:#22c55e;--ha-warning:#f59e0b;--ha-error:#ef4444;--ha-bg-dark:#0f0f23;--ha-bg-card:#1a1a2e;--ha-bg-card-hover:#1e1e35;--ha-border:#2a2a4a;--ha-text:#e2e8f0;--ha-text-muted:#94a3b8;--ha-radius:12px;--ha-radius-sm:8px;--ha-shadow:0 4px 6px -1px rgba(0,0,0,.3)}.ha-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:var(--ha-radius-sm);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s ease;line-height:1.4}.ha-btn-primary{background:var(--ha-primary);color:#fff}.ha-btn-primary:hover{background:var(--ha-primary-dark);color:#fff}.ha-btn-secondary{background:var(--ha-border);color:var(--ha-text)}.ha-btn-secondary:hover{background:#3a3a5a;color:#fff}.ha-btn-success{background:var(--ha-success);color:#fff}.ha-btn-success:hover{background:#16a34a;color:#fff}.ha-btn-lg{padding:14px 28px;font-size:16px}.ha-btn-sm{padding:6px 12px;font-size:12px}.ha-progress-bar-container{width:100%;height:24px;background:var(--ha-border);border-radius:12px;overflow:hidden;position:relative}.ha-progress-bar{height:100%;background:linear-gradient(90deg,var(--ha-primary),var(--ha-accent));border-radius:12px;transition:width .5s ease;display:flex;align-items:center;justify-content:center;min-width:40px}.ha-progress-text{color:#fff;font-size:11px;font-weight:700}.ha-catalog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.ha-catalog-title{color:var(--ha-text);margin:0;font-size:28px}.ha-catalog-filters{display:flex;gap:10px}.ha-filter-select{padding:8px 12px;background:var(--ha-bg-card);border:1px solid var(--ha-border);color:var(--ha-text);border-radius:var(--ha-radius-sm);font-size:14px}.ha-catalog-grid{display:grid;gap:24px}.ha-cols-2{grid-template-columns:repeat(2,1fr)}.ha-cols-3{grid-template-columns:repeat(3,1fr)}.ha-cols-4{grid-template-columns:repeat(4,1fr)}@media (max-width:768px){.ha-catalog-grid{grid-template-columns:1fr !important}.ha-catalog-header{flex-direction:column;align-items:flex-start}}.ha-course-card{background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius);overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease,box-shadow .2s ease}.ha-course-card:hover{transform:translateY(-4px);box-shadow:0 12px 24px rgba(0,0,0,.4)}.ha-course-card-image{position:relative;aspect-ratio:16/9;overflow:hidden}.ha-course-card-image img{width:100%;height:100%;object-fit:cover}.ha-badge{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:20px;font-size:12px;font-weight:700}.ha-badge-free{background:var(--ha-success);color:#fff}.ha-course-card-body{padding:20px;flex:1}.ha-course-card-title{margin:0 0 8px;font-size:18px}.ha-course-card-title a{color:var(--ha-text);text-decoration:none}.ha-course-card-title a:hover{color:var(--ha-primary)}.ha-course-card-excerpt{color:var(--ha-text-muted);font-size:14px;margin:0 0 12px}.ha-course-card-meta{display:flex;flex-wrap:wrap;gap:12px}.ha-meta-item{display:inline-flex;align-items:center;gap:4px;color:var(--ha-text-muted);font-size:13px}.ha-course-card-footer{padding:16px 20px;border-top:1px solid var(--ha-border);display:flex;justify-content:space-between;align-items:center}.ha-course-card-price{font-size:20px;font-weight:700;color:var(--ha-primary)}.ha-course-hero{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:40px}.ha-course-hero-image img{width:100%;border-radius:var(--ha-radius)}.ha-course-title{color:var(--ha-text);margin:0 0 16px;font-size:32px}.ha-course-meta-row{display:flex;gap:20px;margin-bottom:20px}.ha-course-price-box{display:flex;align-items:center;gap:20px;margin-top:20px}.ha-price{font-size:36px;font-weight:700;color:var(--ha-primary)}.ha-course-progress-section{margin-top:20px}@media (max-width:768px){.ha-course-hero{grid-template-columns:1fr}}.ha-course-description{margin-bottom:40px;color:var(--ha-text);line-height:1.7}.ha-course-description h2{color:var(--ha-text);margin-bottom:16px}.ha-course-syllabus h2{color:var(--ha-text);margin-bottom:20px}.ha-module{background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius);margin-bottom:16px;overflow:hidden}.ha-module-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:rgba(168,85,247,.05);border-bottom:1px solid var(--ha-border)}.ha-module-title{margin:0;font-size:16px;color:var(--ha-text)}.ha-module-number{display:inline-block;background:var(--ha-primary);color:#fff;padding:2px 8px;border-radius:4px;font-size:12px;margin-right:8px}.ha-module-count{color:var(--ha-text-muted);font-size:13px}.ha-module-description{padding:12px 20px 0;color:var(--ha-text-muted);font-size:14px}.ha-lesson-list{list-style:none;padding:0;margin:0}.ha-lesson-item{display:flex;align-items:center;gap:10px;padding:12px 20px;border-bottom:1px solid var(--ha-border);color:var(--ha-text);font-size:14px}.ha-lesson-item:last-child{border-bottom:none}.ha-lesson-item.ha-completed{opacity:.7}.ha-lesson-link{color:var(--ha-text);text-decoration:none;flex:1}.ha-lesson-link:hover{color:var(--ha-primary)}.ha-lesson-title-locked{color:var(--ha-text-muted);flex:1}.ha-lesson-duration{color:var(--ha-text-muted);font-size:12px}.ha-quiz-item{background:rgba(99,102,241,.05)}.ha-lesson-top-bar{display:flex;align-items:center;gap:20px;padding:12px 0;margin-bottom:24px;border-bottom:1px solid var(--ha-border)}.ha-back-link{color:var(--ha-primary);text-decoration:none;font-size:14px;white-space:nowrap}.ha-lesson-position{color:var(--ha-text-muted);font-size:13px;white-space:nowrap}.ha-lesson-top-bar .ha-progress-bar-container{height:8px;flex:1}.ha-lesson-top-bar .ha-progress-bar{min-width:0}.ha-lesson-title{color:var(--ha-text);margin:0 0 16px;font-size:28px}.ha-lesson-meta{margin-bottom:20px}.ha-video-container{margin:24px 0;border-radius:var(--ha-radius);overflow:hidden}.ha-video-container iframe{width:100%;aspect-ratio:16/9;border:none}.ha-lesson-body{color:var(--ha-text);line-height:1.8;margin:24px 0}.ha-lesson-download{margin:24px 0}.ha-lesson-complete-section{text-align:center;margin:40px 0}.ha-lesson-completed-badge{text-align:center;padding:16px;background:rgba(34,197,94,.1);border-radius:var(--ha-radius-sm);color:var(--ha-success);font-weight:600;margin:24px 0}.ha-lesson-navigation{display:flex;justify-content:space-between;margin-top:40px;padding-top:20px;border-top:1px solid var(--ha-border)}.ha-nav-btn{padding:12px 20px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius-sm);color:var(--ha-text);text-decoration:none;font-size:14px;max-width:45%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ha-nav-btn:hover{border-color:var(--ha-primary);color:var(--ha-primary)}.ha-quiz-player{max-width:800px;margin:0 auto}.ha-quiz-header{margin-bottom:30px}.ha-quiz-title{color:var(--ha-text);margin:0 0 12px}.ha-quiz-meta{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}.ha-quiz-best-score{padding:10px 16px;background:rgba(34,197,94,.1);border-radius:var(--ha-radius-sm);color:var(--ha-success)}.ha-quiz-start{text-align:center;padding:40px}.ha-quiz-timer{text-align:center;font-size:24px;font-weight:700;color:var(--ha-warning);margin-bottom:20px}.ha-quiz-progress-bar{height:4px;background:var(--ha-border);border-radius:2px;margin-bottom:30px}.ha-quiz-progress-fill{height:100%;background:var(--ha-primary);border-radius:2px;transition:width .3s ease}.ha-question{background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius);padding:24px;margin-bottom:20px}.ha-question-text{color:var(--ha-text);font-size:16px;font-weight:600;margin:0 0 16px}.ha-question-options{display:flex;flex-direction:column;gap:8px}.ha-option-label{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--ha-bg-dark);border:1px solid var(--ha-border);border-radius:var(--ha-radius-sm);cursor:pointer;color:var(--ha-text);transition:border-color .2s}.ha-option-label:hover{border-color:var(--ha-primary)}.ha-option-label input{accent-color:var(--ha-primary)}.ha-option-label.ha-selected{border-color:var(--ha-primary);background:rgba(168,85,247,.1)}.ha-option-label.ha-correct{border-color:var(--ha-success);background:rgba(34,197,94,.1)}.ha-option-label.ha-incorrect{border-color:var(--ha-error);background:rgba(239,68,68,.1)}.ha-quiz-actions{display:flex;justify-content:space-between;margin-top:20px}.ha-quiz-result-card{text-align:center;padding:40px;background:var(--ha-bg-card);border-radius:var(--ha-radius);border:1px solid var(--ha-border)}.ha-result-score{font-size:64px;font-weight:700;margin-bottom:8px}.ha-result-passed{color:var(--ha-success)}.ha-result-failed{color:var(--ha-error)}.ha-dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:30px;flex-wrap:wrap;gap:20px}.ha-dashboard-user{display:flex;align-items:center;gap:16px}.ha-dashboard-user img{border-radius:50%}.ha-dashboard-user h2{margin:0;color:var(--ha-text)}.ha-text-muted{color:var(--ha-text-muted)}.ha-dashboard-stats{display:flex;gap:24px}.ha-dash-stat{text-align:center;padding:16px 24px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius-sm)}.ha-dash-stat-value{font-size:24px;font-weight:700;color:var(--ha-primary)}.ha-dash-stat-label{font-size:12px;color:var(--ha-text-muted);margin-top:4px}.ha-dashboard-section{margin-bottom:30px}.ha-dashboard-section h3{color:var(--ha-text);margin:0 0 16px}.ha-badges-grid{display:flex;flex-wrap:wrap;gap:12px}.ha-badge-item{display:flex;align-items:center;gap:8px;padding:8px 14px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:20px;font-size:13px;color:var(--ha-text)}.ha-badge-icon{font-size:18px}.ha-dash-course-card{display:flex;gap:16px;padding:16px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius);margin-bottom:12px}.ha-dash-course-thumb{width:80px;flex-shrink:0}.ha-dash-course-thumb img{width:100%;border-radius:var(--ha-radius-sm)}.ha-dash-course-info{flex:1}.ha-dash-course-info h4{margin:0 0 8px}.ha-dash-course-info h4 a{color:var(--ha-text);text-decoration:none}.ha-dash-course-info h4 a:hover{color:var(--ha-primary)}.ha-dash-course-status{margin-top:8px;display:flex;align-items:center;gap:12px}.ha-status{font-size:13px;font-weight:600}.ha-status-active{color:var(--ha-accent)}.ha-status-completed{color:var(--ha-success)}.ha-certificates-list{display:flex;flex-direction:column;gap:8px}.ha-cert-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius-sm)}.ha-cert-icon{font-size:24px}.ha-cert-info{display:flex;flex-direction:column;gap:2px;color:var(--ha-text)}.ha-cert-info code{color:var(--ha-primary);font-size:13px}.ha-cert-info small{color:var(--ha-text-muted)}.ha-leaderboard-title{color:var(--ha-text);text-align:center;margin-bottom:24px}.ha-leaderboard-row{display:flex;align-items:center;gap:16px;padding:12px 20px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius-sm);margin-bottom:8px}.ha-leaderboard-row.ha-rank-top{border-color:var(--ha-primary)}.ha-leaderboard-row.ha-current-user{background:rgba(168,85,247,.1)}.ha-lb-rank{font-size:20px;font-weight:700;width:40px;text-align:center;color:var(--ha-text)}.ha-lb-avatar img{border-radius:50%}.ha-lb-name{flex:1;color:var(--ha-text);font-weight:500}.ha-lb-you{color:var(--ha-primary);font-size:12px}.ha-lb-badges{display:flex;gap:4px}.ha-lb-points{color:var(--ha-primary);font-size:16px}.ha-certificate-verify{text-align:center;padding:40px}.ha-certificate-verify h2{color:var(--ha-text)}.ha-certificate-verify p{color:var(--ha-text-muted)}.ha-verify-form{display:flex;justify-content:center;gap:12px;margin-top:20px}.ha-input{padding:10px 16px;background:var(--ha-bg-card);border:1px solid var(--ha-border);color:var(--ha-text);border-radius:var(--ha-radius-sm);font-size:14px}.ha-input-lg{padding:14px 20px;font-size:18px;letter-spacing:2px;text-align:center}.ha-error{color:var(--ha-error);padding:16px;background:rgba(239,68,68,.1);border-radius:var(--ha-radius-sm)}.ha-access-denied{text-align:center;padding:40px;color:var(--ha-text)}.ha-no-results{text-align:center;color:var(--ha-text-muted);padding:40px}.ha-login-required{text-align:center;padding:40px;color:var(--ha-text)}.ha-login-required a{color:var(--ha-primary)}.ha-auth-container{display:flex;justify-content:center;padding:40px 20px}.ha-auth-card{width:100%;max-width:440px;background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius);padding:40px}.ha-auth-header{text-align:center;margin-bottom:28px}.ha-auth-header h2{color:var(--ha-text);margin:0 0 8px;font-size:24px}.ha-auth-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.3);color:var(--ha-error);padding:12px 16px;border-radius:var(--ha-radius-sm);font-size:14px;margin-bottom:20px}.ha-auth-form{display:flex;flex-direction:column;gap:18px}.ha-form-group{display:flex;flex-direction:column;gap:6px}.ha-form-group label{color:var(--ha-text);font-size:14px;font-weight:500}.ha-input-full{width:100%;box-sizing:border-box}.ha-password-wrapper{position:relative;display:flex;align-items:center}.ha-password-wrapper .ha-input{width:100%;padding-right:44px;box-sizing:border-box}.ha-password-toggle{position:absolute;right:10px;background:0 0;border:none;color:var(--ha-text-muted);cursor:pointer;padding:4px;display:flex;align-items:center}.ha-password-toggle:hover{color:var(--ha-primary)}.ha-password-toggle.ha-active{color:var(--ha-primary)}.ha-password-strength{display:flex;align-items:center;gap:8px;min-height:20px;font-size:12px;color:var(--ha-text-muted)}.ha-strength-bar{height:4px;border-radius:2px;flex:1;transition:background .3s}.ha-strength-weak{background:var(--ha-error)}.ha-strength-fair{background:var(--ha-warning)}.ha-strength-good{background:#eab308}.ha-strength-strong{background:var(--ha-success)}.ha-strength-excellent{background:var(--ha-accent)}.ha-form-row{display:flex;justify-content:space-between;align-items:center}.ha-checkbox-label{display:flex;align-items:center;gap:8px;color:var(--ha-text);font-size:14px;cursor:pointer}.ha-checkbox-label input[type=checkbox]{accent-color:var(--ha-primary)}.ha-link-small{color:var(--ha-primary);font-size:13px;text-decoration:none}.ha-link-small:hover{text-decoration:underline}.ha-btn-full{width:100%;justify-content:center;padding:14px;font-size:16px}.ha-auth-footer{text-align:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--ha-border);color:var(--ha-text-muted);font-size:14px}.ha-auth-footer a{color:var(--ha-primary);text-decoration:none;font-weight:600}.ha-auth-footer a:hover{text-decoration:underline}.ha-auth-logged-in{text-align:center;padding:40px 20px}.ha-auth-avatar{margin-bottom:16px}.ha-auth-avatar img{border-radius:50%}.ha-auth-logged-in h3{color:var(--ha-text);margin:0 0 8px}.ha-auth-actions{display:flex;justify-content:center;gap:12px;margin-top:20px}.ha-collab-banner{display:flex;align-items:center;gap:16px;padding:16px 20px;background:rgba(168,85,247,.08);border:1px solid rgba(168,85,247,.2);border-radius:var(--ha-radius)}.ha-collab-banner-icon{font-size:28px}.ha-collab-banner-text{flex:1}.ha-collab-banner-text strong{color:var(--ha-text)}.ha-collab-banner-text p{margin:2px 0 0;font-size:13px}@media (max-width:640px){.ha-collab-banner{flex-direction:column;text-align:center}}@media (max-width:640px){.ha-auth-card{padding:24px}.ha-form-row{flex-direction:column;gap:8px;align-items:flex-start}}@media (max-width:640px){.ha-dashboard-stats{flex-wrap:wrap}.ha-dash-stat{flex:1;min-width:80px}.ha-quiz-actions{flex-direction:column;gap:10px}.ha-lesson-navigation{flex-direction:column;gap:10px}.ha-nav-btn{max-width:100%}}.ha-course-cta{margin-top:20px;padding:24px;background:rgba(168,85,247,.06);border:1px solid rgba(168,85,247,.2);border-radius:var(--ha-radius)}.ha-cta-text{color:var(--ha-text-muted);font-size:15px;margin:0 0 16px;line-height:1.5}.ha-cta-buttons{display:flex;gap:12px;flex-wrap:wrap}.ha-access-denied{text-align:center;padding:60px 20px;color:var(--ha-text)}.ha-access-denied h2{color:var(--ha-text);margin:0 0 12px;font-size:24px}.ha-access-denied p{color:var(--ha-text-muted);font-size:16px;margin:0 0 24px;max-width:500px;margin-left:auto;margin-right:auto}.ha-access-denied .ha-cta-buttons{justify-content:center}.ha-catalog-cta{display:flex;align-items:center;justify-content:space-between;gap:24px;margin-top:40px;padding:28px 32px;background:linear-gradient(135deg,rgba(168,85,247,.12) 0%,rgba(99,102,241,.12) 100%);border:1px solid rgba(168,85,247,.25);border-radius:var(--ha-radius)}.ha-catalog-cta h3{color:var(--ha-text);margin:0 0 6px;font-size:20px}.ha-catalog-cta p{color:var(--ha-text-muted);margin:0;font-size:14px}@media (max-width:640px){.ha-catalog-cta{flex-direction:column;text-align:center}}.ha-notification{position:fixed;bottom:24px;right:24px;padding:14px 24px;border-radius:var(--ha-radius-sm);font-size:14px;font-weight:500;z-index:10000;opacity:0;transform:translateY(20px);transition:opacity .3s ease,transform .3s ease;max-width:380px;box-shadow:0 8px 24px rgba(0,0,0,.4)}.ha-notification-show{opacity:1;transform:translateY(0)}.ha-notification-success{background:var(--ha-success);color:#fff}.ha-notification-error{background:var(--ha-error);color:#fff}.ha-notification-info{background:var(--ha-secondary);color:#fff}.ha-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);display:flex;align-items:center;justify-content:center;z-index:10001;opacity:0;transition:opacity .3s ease;padding:20px}.ha-modal-overlay.ha-modal-show{opacity:1}.ha-modal-card{background:var(--ha-bg-card);border:1px solid var(--ha-border);border-radius:var(--ha-radius);padding:48px 40px;text-align:center;max-width:480px;width:100%;transform:scale(.9);transition:transform .3s ease}.ha-modal-show .ha-modal-card{transform:scale(1)}.ha-modal-icon{font-size:64px;margin-bottom:16px}.ha-modal-card h2{color:var(--ha-text);margin:0 0 12px;font-size:28px}.ha-modal-card p{color:var(--ha-text-muted);margin:0 0 8px;font-size:16px}.ha-modal-actions{margin-top:24px;display:flex;justify-content:center;gap:12px}.ha-spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:ha-spin .6s linear infinite;vertical-align:middle}@keyframes ha-spin{to{transform:rotate(360deg)}}.ha-result-icon{font-size:56px;margin-bottom:8px}.ha-result-label{font-size:20px;color:var(--ha-text);margin:8px 0}.ha-result-actions{display:flex;justify-content:center;gap:12px;margin-top:24px}.ha-quiz-result-card p{color:var(--ha-text);margin:4px 0}