*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#0077b6;--primary-hover:#005f99;--green:#10b981;--pink:#e63946;--yellow:#f59e0b;--red:#ef4444;--bg:#eef3f8;--bg-card:#fff;--bg-card2:#f2f6fb;--border:#ccd8e6;--text:#1a2d3e;--text-muted:#5e7a92;--text-light:#3a556a;--radius:12px;--radius-sm:8px;--shadow:0 4px 24px #005aa01a;--transition:.2s ease}html{font-size:16px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;background:0 0;border:none;font-family:inherit}ul{list-style:none}img{max-width:100%}.mt-16{margin-top:16px}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius-sm);transition:background var(--transition), transform var(--transition);justify-content:center;align-items:center;gap:6px;padding:10px 22px;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary:hover:not(:disabled){background:var(--primary-hover);transform:translateY(-1px)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary.btn-full{width:100%}.btn-primary.btn-lg{padding:12px 28px;font-size:1rem}.btn-secondary{background:var(--bg-card2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);transition:background var(--transition);justify-content:center;align-items:center;gap:6px;padding:10px 22px;font-size:.9rem;font-weight:500;display:inline-flex}.btn-secondary:hover{background:var(--bg-card2);border-color:var(--text-muted)}.btn-secondary.btn-lg{padding:12px 28px;font-size:1rem}.btn-outline{color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius-sm);transition:color var(--transition), border-color var(--transition);background:0 0;justify-content:center;align-items:center;gap:6px;padding:10px 22px;font-size:.9rem;font-weight:500;display:inline-flex}.btn-outline:hover{color:var(--text);border-color:var(--text-muted)}.btn-outline.btn-lg{padding:12px 28px;font-size:1rem}.btn-disabled{background:var(--bg-card2);color:var(--text-muted);border:1px dashed var(--border);border-radius:var(--radius-sm);cursor:not-allowed;justify-content:center;align-items:center;width:100%;padding:10px 22px;font-size:.9rem;font-weight:500;display:inline-flex}.btn-loading{align-items:center;gap:8px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}.spinner-sm{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen{justify-content:center;align-items:center;min-height:calc(100vh - 64px);display:flex}.progress-bar-bg{background:#00000014;border-radius:99px;height:6px;overflow:hidden}.progress-bar-fill{background:var(--primary);border-radius:99px;height:100%;transition:width .4s}.app-layout{flex-direction:column;min-height:100vh;display:flex}.main-content{width:100%;max-width:1200px;margin:0 auto;padding:24px 20px 60px}.header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:#fffffff2;height:64px;position:sticky;top:0;box-shadow:0 1px 8px #005aa012}.header-inner{align-items:center;gap:24px;max-width:1200px;height:100%;margin:0 auto;padding:0 20px;display:flex}.header-logo{align-items:center;gap:8px;font-size:1.1rem;font-weight:700;display:flex}.logo-icon{font-size:1.4rem}.logo-text{background:linear-gradient(90deg, var(--primary), #00b4d8);-webkit-text-fill-color:transparent;-webkit-background-clip:text}.header-nav{flex:1;gap:4px;display:flex}.nav-link{border-radius:var(--radius-sm);color:var(--text-muted);transition:color var(--transition), background var(--transition);padding:6px 14px;font-size:.9rem;font-weight:500}.nav-link:hover{color:var(--primary);background:#0077b612}.header-user{align-items:center;gap:10px;margin-left:auto;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex}.user-info{flex-direction:column;min-width:0;max-width:140px;display:flex}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:600;line-height:1.2;overflow:hidden}.user-role{color:var(--text-muted);text-transform:capitalize;white-space:nowrap;text-overflow:ellipsis;font-size:.73rem;overflow:hidden}.btn-logout{border-radius:var(--radius-sm);width:34px;height:34px;color:var(--text-muted);transition:color var(--transition), background var(--transition);justify-content:center;align-items:center;display:flex}.btn-logout:hover{color:var(--red);background:#ef44441a}.breadcrumb{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:24px;font-size:.84rem;display:flex}.breadcrumb a:hover{color:var(--text)}.breadcrumb-sep{opacity:.5}.login-page{justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex;position:relative}.login-bg{z-index:0;background:radial-gradient(at 20% 60%,#0077b62e 0%,#0000 55%),radial-gradient(at 80% 20%,#00b4d824 0%,#0000 50%);position:fixed;inset:0}.login-card{z-index:1;background:var(--bg-card);border:1px solid var(--border);width:100%;max-width:440px;box-shadow:var(--shadow);border-radius:20px;padding:40px 36px;position:relative}.login-header{text-align:center;margin-bottom:32px}.login-logo{margin-bottom:12px;font-size:3rem;line-height:1}.login-title{background:linear-gradient(90deg, var(--primary), #00b4d8);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:1.8rem;font-weight:800}.login-subtitle{color:var(--text-muted);margin-top:6px;font-size:.9rem}.login-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text-light);font-size:.85rem;font-weight:600}.form-input{background:var(--bg-card2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:border-color var(--transition);outline:none;padding:11px 14px;font-size:.95rem}.form-input:focus{border-color:var(--primary)}.form-error{border-radius:var(--radius-sm);color:#f87171;background:#ef44441a;border:1px solid #ef44444d;align-items:center;gap:8px;padding:10px 14px;font-size:.86rem;display:flex}.login-demos{margin-top:28px}.demos-title{color:var(--text-muted);text-align:center;text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:.8rem}.demos-grid{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.demo-btn{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);text-align:left;cursor:pointer;transition:border-color var(--transition), background var(--transition);align-items:center;gap:8px;padding:10px 8px;display:flex}.demo-btn:hover{border-color:var(--primary);background:#0077b614}.demo-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;font-size:.7rem;font-weight:700;display:flex}.demo-name{color:var(--text);font-size:.78rem;font-weight:600;display:block}.demo-email{color:var(--text-muted);font-size:.68rem;display:block}.welcome-banner{background:linear-gradient(135deg,#0077b626 0%,#00b4d81a 100%);border:1px solid #0077b640;border-radius:16px;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;padding:28px 32px;display:flex}.welcome-greeting{font-size:1.6rem;font-weight:800}.welcome-greeting span{color:#00b4d8}.welcome-sub{color:var(--text-muted);margin-top:4px}.welcome-stats{flex-shrink:0;gap:16px;display:flex}.stat-pill{border-radius:var(--radius-sm);border:1px solid var(--border);background:#0077b60f;flex-direction:column;align-items:center;min-width:80px;padding:12px 20px;display:flex}.stat-num{color:var(--primary);font-size:1.5rem;font-weight:800}.stat-label{color:var(--text-muted);font-size:.75rem}.filter-tabs{gap:4px;margin-bottom:24px;display:flex}.filter-tab{border-radius:var(--radius-sm);color:var(--text-muted);transition:all var(--transition);padding:8px 20px;font-size:.9rem;font-weight:500}.filter-tab:hover{color:var(--text);background:var(--border)}.filter-tab.active{background:var(--primary);color:#fff}.courses-grid,.loading-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;display:grid}.skeleton-card{background:linear-gradient(90deg,#e8eff7 25%,#d6e3ef 50%,#e8eff7 75%) 0 0/200% 100%;border-radius:16px;height:360px;animation:1.5s infinite shimmer}@keyframes shimmer{to{background-position:-200% 0}}.empty-state{text-align:center;color:var(--text-muted);padding:60px 0}.empty-icon{margin-bottom:12px;font-size:3rem;display:block}.course-card{background:var(--bg-card);border:1px solid var(--border);cursor:pointer;transition:transform var(--transition), box-shadow var(--transition), border-color var(--transition);border-radius:16px;flex-direction:column;display:flex;overflow:hidden}.course-card:hover{border-color:#0077b659;transform:translateY(-4px);box-shadow:0 12px 40px #005aa026}.course-card-banner{justify-content:center;align-items:center;height:140px;display:flex;position:relative}.course-icon{filter:drop-shadow(0 4px 8px #0000004d);font-size:3.5rem}.course-level-badge{color:#fff;border-radius:99px;padding:3px 10px;font-size:.74rem;font-weight:700;position:absolute;top:12px;right:12px}.course-locked-overlay{color:#ffffffb3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0009;justify-content:center;align-items:center;font-size:.85rem;font-weight:600;display:flex;position:absolute;inset:0}.course-card-body{flex-direction:column;flex:1;gap:10px;padding:18px;display:flex}.course-card-title{font-size:1.05rem;font-weight:700;line-height:1.3}.course-card-desc{color:var(--text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.83rem;line-height:1.5;display:-webkit-box;overflow:hidden}.course-card-meta{flex-wrap:wrap;gap:14px;display:flex}.meta-item{color:var(--text-muted);align-items:center;gap:4px;font-size:.78rem;display:flex}.meta-item svg{color:var(--yellow);flex-shrink:0}.course-card-instructor{color:var(--text-muted);align-items:center;gap:5px;font-size:.8rem;display:flex}.course-card-btn{margin-top:auto}.course-hero{border-radius:16px;margin-bottom:28px;padding:32px;position:relative;overflow:hidden}.course-hero:before{content:"";background:#0000004d;position:absolute;inset:0}.course-hero-content,.course-progress-box{z-index:1;position:relative}.course-hero-content{align-items:flex-start;gap:20px;margin-bottom:24px;display:flex}.course-hero-icon{flex-shrink:0;font-size:3rem}.course-hero-level{background:#fff3;border-radius:99px;margin-bottom:6px;padding:2px 10px;font-size:.75rem;font-weight:700;display:inline-block}.course-hero-title{margin-bottom:8px;font-size:1.5rem;font-weight:800}.course-hero-desc{opacity:.85;max-width:600px;margin-bottom:10px;font-size:.9rem}.course-hero-meta{opacity:.8;flex-wrap:wrap;gap:16px;font-size:.85rem;display:flex}.course-progress-box{border-radius:var(--radius-sm);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000040;padding:16px}.progress-header{justify-content:space-between;margin-bottom:8px;font-size:.85rem;display:flex}.progress-pct{color:#fff;font-weight:700}.progress-sub{opacity:.7;margin-top:6px;font-size:.78rem}.course-layout{grid-template-columns:1fr 340px;align-items:start;gap:24px;display:grid}.video-section{flex-direction:column;gap:20px;display:flex}.video-player{border-radius:var(--radius);aspect-ratio:16/9;background:#000;position:relative;overflow:hidden}.video-player iframe{border:none;width:100%;height:100%}.video-placeholder{background:var(--bg-card2);width:100%;height:100%;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.play-circle{border:2px solid var(--primary);width:64px;height:64px;color:var(--primary);background:#0077b61f;border-radius:50%;justify-content:center;align-items:center;font-size:1.4rem;display:flex}.video-info{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.video-title{margin-bottom:8px;font-size:1.15rem;font-weight:700}.video-desc{color:var(--text-muted);margin-bottom:16px;font-size:.9rem}.video-actions{justify-content:space-between;align-items:center;gap:12px;display:flex}.video-duration{color:var(--text-muted);font-size:.85rem}.btn-mark{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);color:var(--text-muted);transition:all var(--transition);padding:8px 16px;font-size:.85rem;font-weight:500}.btn-mark:hover{border-color:var(--green);color:var(--green)}.btn-mark-done{border-color:var(--green);color:var(--green);background:#10b9811a}.exam-cta{border-radius:var(--radius);background:linear-gradient(135deg,#0077b612 0%,#10b9810f 100%);border:1px solid #0077b633;justify-content:space-between;align-items:center;gap:20px;padding:24px 28px;display:flex}.exam-cta-text h3{margin-bottom:4px;font-size:1.05rem;font-weight:700}.exam-cta-text p{color:var(--text-muted);font-size:.88rem}.btn-exam{background:var(--primary);color:#fff;border-radius:var(--radius-sm);transition:background var(--transition), transform var(--transition);white-space:nowrap;flex-shrink:0;align-items:center;gap:8px;padding:12px 24px;font-size:.95rem;font-weight:700;display:inline-flex}.btn-exam:hover{background:var(--primary-hover);transform:translateY(-1px)}.playlist{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:sticky;top:84px}.playlist-title{margin-bottom:2px;font-size:1rem;font-weight:700}.playlist-count{color:var(--text-muted);margin-bottom:16px;font-size:.8rem}.playlist-list{flex-direction:column;gap:4px;display:flex}.playlist-item{border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);border:1px solid #0000;align-items:center;gap:12px;padding:10px;display:flex}.playlist-item:hover{background:var(--bg-card2)}.playlist-item.active{background:#0077b614;border-color:#0077b640}.playlist-item.done .playlist-num{color:var(--green);border-color:var(--green);background:#10b98126}.playlist-num{background:var(--bg-card2);border:1px solid var(--border);width:28px;height:28px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.78rem;font-weight:700;display:flex}.check-icon{color:var(--green)}.playlist-info{flex:1;min-width:0}.playlist-item-title{white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;display:block;overflow:hidden}.playlist-item-dur{color:var(--text-muted);font-size:.75rem}.playing-badge{color:var(--primary);flex-shrink:0;font-size:.75rem}.playlist-exam-link{border-top:1px solid var(--border);margin-top:16px;padding-top:16px}.exam-intro-card{text-align:center;background:var(--bg-card);border:1px solid var(--border);border-radius:20px;max-width:600px;margin:0 auto;padding:48px 40px}.exam-intro-icon{border-radius:20px;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 20px;font-size:2.5rem;display:flex}.exam-intro-title{margin-bottom:10px;font-size:1.6rem;font-weight:800}.exam-intro-desc{color:var(--text-muted);margin-bottom:28px}.exam-rules{flex-wrap:wrap;justify-content:center;gap:16px;margin-bottom:32px;display:flex}.exam-rule{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);flex:1;align-items:center;gap:10px;min-width:130px;max-width:180px;padding:14px 18px;display:flex}.rule-icon{font-size:1.5rem}.exam-rule strong{font-size:.95rem;display:block}.exam-rule span{color:var(--text-muted);font-size:.78rem}.exam-intro-actions{flex-wrap:wrap;justify-content:center;gap:12px;display:flex}.exam-container{grid-template-columns:220px 1fr;align-items:start;gap:24px;display:grid}.exam-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;position:sticky;top:84px}.exam-sidebar-title{margin-bottom:14px;font-size:.9rem;font-weight:700}.question-dots{flex-wrap:wrap;gap:8px;margin-bottom:16px;display:flex}.question-dot{background:var(--bg-card2);border:1px solid var(--border);width:34px;height:34px;color:var(--text-muted);transition:all var(--transition);border-radius:50%;font-size:.82rem;font-weight:600}.question-dot:hover{border-color:var(--primary);color:var(--primary)}.dot-answered{border-color:var(--primary);color:var(--primary);background:#0077b61f}.dot-current{background:var(--primary)!important;border-color:var(--primary)!important;color:#fff!important}.exam-progress-info{color:var(--text-muted);font-size:.8rem}.exam-progress-info span{margin-bottom:6px;display:block}.exam-main{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.exam-question-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.question-counter{color:var(--text-muted);font-size:.85rem}.question-status{font-size:.85rem;font-weight:600}.exam-question-text{margin-bottom:24px;font-size:1.15rem;font-weight:700;line-height:1.5}.exam-options{flex-direction:column;gap:10px;margin-bottom:28px;display:flex}.exam-option{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);text-align:left;transition:all var(--transition);align-items:center;gap:14px;padding:14px 18px;display:flex}.exam-option:hover{border-color:var(--primary);background:#0077b60d}.option-selected{border-color:var(--primary)!important;background:#0077b61a!important}.option-letter{background:var(--border);width:28px;height:28px;color:var(--text-muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.option-selected .option-letter{background:var(--primary);color:#fff}.option-text{font-size:.92rem}.exam-nav{justify-content:space-between;gap:12px;display:flex}.btn-muted{opacity:.5}.exam-warning{color:var(--yellow);text-align:center;margin-top:14px;font-size:.84rem}.results-hero{text-align:center;border-radius:16px;margin-bottom:32px;padding:40px 32px}.results-pass{background:linear-gradient(135deg,#10b9811a 0%,#05966912 100%);border:1px solid #10b9814d}.results-fail{background:linear-gradient(135deg,#ef444414 0%,#dc26260d 100%);border:1px solid #ef444440}.results-icon{margin-bottom:8px;font-size:3.5rem}.results-verdict{margin-bottom:16px;font-size:2rem;font-weight:800}.results-pass .results-verdict{color:var(--green)}.results-fail .results-verdict{color:var(--red)}.results-score{margin-bottom:12px}.score-big{font-size:3rem;font-weight:900;display:block}.score-sub{color:var(--text-muted);font-size:1rem}.results-message{color:var(--text-muted);margin-bottom:24px;max-width:500px;margin-inline:auto;font-size:.95rem}.score-gauge{max-width:500px;margin:0 auto}.gauge-track{background:#00000014;border-radius:99px;height:10px;position:relative;overflow:visible}.gauge-fill{border-radius:99px;height:100%;transition:width .6s}.gauge-threshold{background:#0000004d;width:2px;position:absolute;top:-4px;bottom:-4px}.gauge-labels{color:var(--text-muted);justify-content:space-between;margin-top:6px;font-size:.75rem;display:flex}.gauge-pass-label{position:absolute;left:70%;transform:translate(-50%)}.results-review{margin-bottom:32px}.review-title{margin-bottom:16px;font-size:1.2rem;font-weight:700}.review-list{flex-direction:column;gap:16px;display:flex}.review-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.review-correct{border-left:3px solid var(--green)}.review-wrong{border-left:3px solid var(--red)}.review-question-header{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.review-num{color:var(--text-muted);font-size:.8rem}.review-badge{border-radius:99px;padding:2px 10px;font-size:.78rem;font-weight:700}.badge-correct{color:var(--green);background:#10b98126}.badge-wrong{color:var(--red);background:#ef44441f}.review-question{margin-bottom:14px;font-weight:600}.review-options{flex-direction:column;gap:6px;display:flex}.review-option{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);color:var(--text);align-items:center;gap:10px;padding:10px 14px;font-size:.88rem;display:flex}.opt-correct{color:var(--green);background:#10b98114;border-color:#10b98166}.opt-wrong{color:var(--red);background:#ef444414;border-color:#ef444466}.opt-tag{color:var(--green);background:#10b98133;border-radius:99px;margin-left:auto;padding:2px 8px;font-size:.73rem;font-weight:700}.opt-tag-wrong{color:var(--red);background:#ef444433}.results-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:40px;display:flex}.nav-link-admin{font-weight:600;color:var(--primary)!important}.nav-link-admin:hover{background:#0077b61a!important}.admin-shell{background:var(--bg);min-height:100vh;display:flex}.admin-sidebar{background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:248px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.admin-sidebar-header{border-bottom:1px solid var(--border);padding:18px 20px 16px}.admin-brand{align-items:center;gap:10px;display:flex}.admin-brand-icon{font-size:1.5rem}.admin-brand-text{flex-direction:column;display:flex}.admin-brand-name{color:var(--text);font-size:.95rem;font-weight:800;line-height:1.2}.admin-brand-badge{letter-spacing:.08em;background:var(--primary);color:#fff;border-radius:4px;width:fit-content;margin-top:2px;padding:1px 6px;font-size:.62rem;font-weight:700}.admin-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.admin-nav-section{text-transform:uppercase;letter-spacing:.09em;color:var(--text-muted);padding:6px 12px 4px;font-size:.68rem;font-weight:700}.admin-nav-link{border-radius:var(--radius-sm);color:var(--text-muted);transition:background var(--transition), color var(--transition);align-items:center;gap:10px;padding:9px 12px;font-size:.88rem;font-weight:500;display:flex}.admin-nav-link:hover{background:var(--bg-card2);color:var(--text)}.admin-nav-link.active{color:var(--primary);background:#0077b61a;font-weight:600}.admin-nav-link svg{flex-shrink:0}.admin-sidebar-footer{border-top:1px solid var(--border);padding:12px 10px}.admin-user-row{align-items:center;gap:10px;padding:6px 2px;display:flex}.admin-user-info{flex-direction:column;flex:1;min-width:0;display:flex}.admin-user-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:600;display:block;overflow:hidden}.admin-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.72rem;display:block;overflow:hidden}.admin-main{flex:1;min-width:0;padding:32px 36px 60px;overflow-y:auto}.admin-page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:28px;display:flex}.admin-page-title{color:var(--text);font-size:1.5rem;font-weight:800}.admin-page-subtitle{color:var(--text-muted);margin-top:3px;font-size:.88rem}.admin-stats-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:box-shadow var(--transition), transform var(--transition);align-items:center;gap:16px;padding:20px 22px;display:flex}.admin-stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #005aa01a}.admin-stat-icon{border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:50px;height:50px;display:flex}.admin-stat-info{flex:1}.admin-stat-value{font-size:2rem;font-weight:800;line-height:1}.admin-stat-label{color:var(--text-muted);margin-top:4px;font-size:.8rem}.admin-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-bottom:24px;overflow:hidden}.admin-section-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.admin-section-title{font-size:.95rem;font-weight:700}.admin-table-wrap{overflow-x:auto}.admin-table{border-collapse:collapse;width:100%}.admin-table th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-card2);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:.75rem;font-weight:700}.admin-table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 16px;font-size:.88rem}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:var(--bg-card2);transition:background .12s}.admin-table-empty{text-align:center;color:var(--text-muted);padding:40px;font-size:.9rem}.admin-course-mini{align-items:center;gap:10px;display:flex}.admin-course-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:1.1rem;display:flex}.admin-course-title{font-size:.88rem;font-weight:600}.admin-course-dur{color:var(--text-muted);font-size:.74rem}.admin-user-chip{align-items:center;gap:10px;display:flex}.admin-chip-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.72rem;font-weight:700;display:flex}.admin-chip-name{font-size:.88rem;font-weight:600}.admin-chip-email{color:var(--text-muted);font-size:.74rem}.admin-badge{white-space:nowrap;border-radius:99px;padding:3px 9px;font-size:.73rem;font-weight:700}.badge-admin{color:#e63946;background:#e639461a}.badge-student{color:#0077b6;background:#0077b61a}.admin-pill{color:var(--primary);white-space:nowrap;background:#0077b614;border:1px solid #0077b633;border-radius:99px;padding:2px 8px;font-size:.73rem}.btn-icon{border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);border:none;align-items:center;gap:5px;padding:5px 11px;font-size:.8rem;font-weight:500;display:inline-flex}.btn-icon-edit{color:var(--primary);background:#0077b614}.btn-icon-edit:hover{background:#0077b629}.btn-icon-delete{color:var(--red);background:#ef444414}.btn-icon-delete:hover{background:#ef444429}.admin-search{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);color:var(--text);min-width:260px;transition:border-color var(--transition);outline:none;padding:8px 14px;font-family:inherit;font-size:.88rem}.admin-search:focus{border-color:var(--primary)}.modal-overlay{z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;width:100%;max-width:520px;max-height:90vh;padding:28px 28px 24px;overflow-y:auto;box-shadow:0 20px 60px #0000002e}.modal-header{justify-content:space-between;align-items:center;margin-bottom:22px;display:flex}.modal-title{font-size:1.15rem;font-weight:700}.modal-close{border-radius:var(--radius-sm);width:30px;height:30px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--bg-card2);color:var(--text)}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:22px;padding-top:18px;display:flex}.admin-form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.admin-tabs{border-bottom:2px solid var(--border);gap:0;margin-bottom:24px;display:flex}.admin-tab{color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-2px;padding:10px 22px;font-size:.9rem;font-weight:500}.admin-tab:hover{color:var(--text)}.admin-tab.active{color:var(--primary);border-bottom-color:var(--primary);font-weight:600}.admin-back-link{color:var(--text-muted);transition:color var(--transition);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;margin-bottom:18px;font-size:.85rem;display:inline-flex}.admin-back-link:hover{color:var(--primary)}.admin-edit-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.admin-edit-num{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;margin-top:2px;font-size:.72rem;font-weight:700;display:flex}.admin-edit-content{flex:1;min-width:0}.admin-edit-title{margin-bottom:4px;font-size:.9rem;font-weight:600}.admin-edit-sub{color:var(--text-muted);font-size:.78rem}.admin-inline-form{background:var(--bg-card2);border:1px solid var(--primary);border-radius:var(--radius-sm);flex-direction:column;gap:12px;padding:18px 20px;display:flex}.admin-option-preview{cursor:default;border-radius:6px;padding:3px 9px;font-size:.76rem}.admin-option-letter{background:var(--bg-card2);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.73rem;font-weight:700;display:inline-flex}.admin-add-btn{background:var(--bg-card2);border:2px dashed var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-muted);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;gap:8px;padding:12px;font-family:inherit;font-size:.88rem;font-weight:500;display:flex}.admin-add-btn:hover{border-color:var(--primary);color:var(--primary);background:#0077b60a}@media (width<=1024px){.admin-sidebar{width:56px}.admin-brand-text,.admin-nav-link span,.admin-nav-section,.admin-user-info,.admin-user-name,.admin-user-email{display:none}.admin-nav-link{justify-content:center;padding:10px}.admin-main{padding:24px 20px 48px}.admin-form-row{grid-template-columns:1fr}}@media (width<=900px){.course-layout{grid-template-columns:1fr}.playlist{position:static}.exam-container{grid-template-columns:1fr}.exam-sidebar{position:static}.welcome-banner{flex-direction:column}.welcome-stats{flex-direction:row}}@media (width<=600px){.header-inner{padding:0 12px}.user-info{display:none}.main-content{padding:16px 12px 48px}.login-card{padding:28px 20px}.demos-grid{grid-template-columns:1fr}.exam-intro-card{padding:28px 20px}.exam-main{padding:20px 16px}.course-hero{padding:20px}.course-hero-content{flex-direction:column;gap:12px}.exam-cta{text-align:center;flex-direction:column}.results-hero{padding:28px 16px}}.profile-page{max-width:860px}.profile-hero{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);align-items:center;gap:20px;margin-bottom:28px;padding:24px 28px;display:flex}.profile-avatar-big{color:#fff;letter-spacing:1px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:68px;height:68px;font-size:1.5rem;font-weight:800;display:flex}.profile-hero-name{color:var(--text);font-size:1.3rem;font-weight:800}.profile-hero-role{text-transform:uppercase;letter-spacing:.06em;color:var(--primary);background:#0077b61a;border-radius:20px;margin-top:4px;padding:3px 10px;font-size:.8rem;font-weight:600;display:inline-block}.profile-grid{grid-template-columns:1fr 1fr;gap:24px;display:grid}.profile-card{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}.profile-card-header{align-items:flex-start;gap:14px;margin-bottom:24px;display:flex}.profile-card-icon{border-radius:var(--radius-sm);background:#0077b61a;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:1.3rem;display:flex}.profile-card-title{color:var(--text);margin-bottom:2px;font-size:1rem;font-weight:700}.profile-card-sub{color:var(--text-muted);font-size:.8rem}.profile-form{flex-direction:column;gap:18px;display:flex}.form-label-hint{color:var(--text-muted);margin-left:4px;font-size:.78rem;font-weight:400}.profile-avatar-row{align-items:center;gap:12px;display:flex}.profile-avatar-preview{color:#fff;letter-spacing:1px;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:.9rem;font-weight:800;display:flex}.profile-pass-row{align-items:center;gap:8px;display:flex}.profile-pass-row .form-input{flex:1}.profile-pass-toggle{border-radius:var(--radius-sm);background:var(--bg-card2);border:1px solid var(--border);width:40px;height:40px;transition:background var(--transition);flex-shrink:0;justify-content:center;align-items:center;font-size:1rem;display:flex}.profile-pass-toggle:hover{background:var(--border)}.profile-error{color:var(--red);border-radius:var(--radius-sm);background:#ef444414;border:1px solid #ef444433;padding:8px 12px;font-size:.83rem}.profile-success{color:var(--green);border-radius:var(--radius-sm);background:#10b98114;border:1px solid #10b98133;padding:8px 12px;font-size:.83rem}.header-user-link{border-radius:var(--radius-sm);transition:background var(--transition);color:inherit;align-items:center;gap:10px;padding:4px 6px;text-decoration:none;display:flex}.header-user-link:hover{background:#0077b612}@media (width<=760px){.profile-grid{grid-template-columns:1fr}}
