@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500&display=swap";.header{position:sticky;top:0;z-index:100;height:var(--header-height);background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color)}.header-container{max-width:1400px;margin:0 auto;padding:0 24px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}.header-logo{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary)}.logo-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);border-radius:var(--radius-md);color:#fff}.logo-icon svg{width:22px;height:22px}.logo-text{font-size:20px;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo-img{width:42px;height:42px;object-fit:contain;border-radius:var(--radius-sm);transition:filter var(--transition-fast)}[data-theme=light] .logo-img{filter:brightness(.85) contrast(1.1)}.header-nav{display:flex;align-items:center;gap:8px}.nav-link{padding:8px 16px;font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover{color:var(--text-primary);background:var(--bg-tertiary)}.nav-link.active{color:var(--accent-primary);background:var(--bg-tertiary);font-weight:600}.nav-link-admin{color:var(--accent-primary)}.header-actions{display:flex;align-items:center;gap:12px}.theme-toggle svg{width:20px;height:20px}.user-menu{position:relative}.user-avatar-btn{display:flex;align-items:center;gap:10px;padding:6px 12px 6px 6px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast)}.user-avatar-btn:hover{background:var(--bg-secondary);border-color:var(--border-color-strong)}.user-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-secondary);object-fit:cover}.user-name{font-size:14px;font-weight:500;color:var(--text-primary)}.chevron{width:16px;height:16px;color:var(--text-tertiary)}.dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);padding:8px;z-index:50}.dropdown-item{display:flex;align-items:center;gap:12px;padding:10px 12px;font-size:14px;color:var(--text-primary);text-decoration:none;border-radius:var(--radius-md);cursor:pointer;background:none;border:none;width:100%;transition:all var(--transition-fast)}.dropdown-item svg{width:18px;height:18px;color:var(--text-tertiary)}.dropdown-item:hover{background:var(--bg-tertiary)}.dropdown-item-danger{color:var(--error)}.dropdown-item-danger svg{color:var(--error)}.dropdown-divider{height:1px;background:var(--border-color);margin:8px 0}.auth-buttons{display:flex;align-items:center;gap:8px}.mobile-menu-btn{display:none}.mobile-menu-btn svg{width:24px;height:24px}.mobile-menu-overlay{position:fixed;inset:0;background:#00000080;z-index:200;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.mobile-menu{position:fixed;top:0;right:0;width:280px;height:100%;background:var(--bg-secondary);padding:24px;display:flex;flex-direction:column;gap:8px;box-shadow:var(--shadow-xl);overflow-y:auto}.mobile-user-info{display:flex;align-items:center;gap:12px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-lg);margin-bottom:16px}.mobile-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.mobile-user-info span{font-weight:600;font-size:16px;color:var(--text-primary)}.mobile-nav-link{display:flex;align-items:center;gap:14px;padding:14px 16px;font-size:16px;font-weight:500;color:var(--text-primary);text-decoration:none;border-radius:var(--radius-md);border:none;background:none;cursor:pointer;width:100%;transition:all var(--transition-fast)}.mobile-nav-link svg{width:22px;height:22px;color:var(--text-secondary)}.mobile-nav-link:hover{background:var(--bg-tertiary)}.mobile-nav-primary{background:var(--accent-gradient);color:#fff}.mobile-nav-primary svg{color:#fff}.mobile-nav-primary:hover{opacity:.9}.mobile-nav-logout{color:var(--error)}.mobile-nav-logout svg{color:var(--error)}.mobile-nav-divider{height:1px;background:var(--border-color);margin:12px 0}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.animate-slide-in{animation:slideIn .3s ease-out}.desktop-only{display:flex}@media(max-width:768px){.desktop-only{display:none!important}.mobile-menu-btn{display:flex}.header-container{padding:0 16px}}.course-card{display:flex;flex-direction:column;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden;text-decoration:none;color:inherit;transition:all var(--transition-normal);opacity:0}.course-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl);border-color:var(--accent-primary)}.course-thumbnail{position:relative;height:180px;overflow:hidden}.course-thumbnail img{width:100%;height:100%;object-fit:cover;transition:transform var(--transition-slow)}.course-card:hover .course-thumbnail img{transform:scale(1.1)}.course-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.6) 0%,transparent 50%);display:flex;align-items:flex-end;padding:16px}.course-category{padding:4px 12px;font-size:12px;font-weight:600;color:#fff;background:var(--accent-gradient);border-radius:var(--radius-full)}.course-content{flex:1;display:flex;flex-direction:column;padding:20px}.course-title{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px;line-height:1.3}.course-description{font-size:14px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin-bottom:16px}.course-meta{margin-bottom:16px}.content-badges{display:flex;flex-wrap:wrap;gap:8px}.content-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:12px;background:var(--bg-tertiary);border-radius:var(--radius-full);color:var(--text-secondary)}.course-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:16px;border-top:1px solid var(--border-color)}.course-author{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.course-author svg{width:16px;height:16px}.course-arrow{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);transition:all var(--transition-fast)}.course-arrow svg{width:18px;height:18px}.course-card:hover .course-arrow{background:var(--accent-primary);color:#fff;transform:translate(4px)}.home-page{min-height:100vh}.hero{position:relative;min-height:calc(100vh - var(--header-height));display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;overflow:hidden}.hero-background{position:absolute;inset:0;overflow:hidden;z-index:-1}.hero-orb{position:absolute;border-radius:50%;filter:blur(100px);opacity:.5;animation:float 6s ease-in-out infinite}.hero-orb-1{width:600px;height:600px;background:var(--accent-primary);top:-200px;right:-100px;animation-delay:0s}.hero-orb-2{width:500px;height:500px;background:var(--accent-secondary);bottom:-150px;left:-100px;animation-delay:2s}.hero-orb-3{width:400px;height:400px;background:#ec4899;top:50%;left:50%;transform:translate(-50%,-50%);animation-delay:4s;opacity:.3}.hero-content{text-align:center;max-width:800px;z-index:1}.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:24px}.badge-icon{font-size:16px}.hero-title{font-size:clamp(40px,8vw,72px);font-weight:800;line-height:1.1;color:var(--text-primary);margin-bottom:24px}.hero-subtitle{font-size:clamp(16px,2.5vw,20px);color:var(--text-secondary);line-height:1.6;margin-bottom:40px}.hero-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:60px}.hero-actions .btn{min-width:160px}.hero-stats{display:flex;align-items:center;justify-content:center;gap:32px;padding:24px 40px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl)}.stat{display:flex;flex-direction:column;align-items:center}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary);background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.stat-divider{width:1px;height:40px;background:var(--border-color)}.hero-scroll-indicator{position:absolute;bottom:40px;color:var(--text-tertiary)}.hero-scroll-indicator svg{width:24px;height:24px}.courses-section{padding:80px 0;background:var(--bg-secondary)}.section-header{display:flex;flex-direction:column;gap:32px;margin-bottom:48px}.section-title-wrapper{text-align:center}.section-title{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.section-subtitle{font-size:16px;color:var(--text-secondary)}.courses-filters{display:flex;flex-wrap:wrap;gap:16px;justify-content:center;align-items:center}.search-box{position:relative;width:100%;max-width:320px}.search-box svg{position:absolute;left:16px;top:50%;transform:translateY(-50%);width:20px;height:20px;color:var(--text-tertiary)}.search-input{width:100%;padding:12px 16px 12px 48px;font-family:inherit;font-size:14px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-primary);transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.category-filter{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.category-btn{padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-full);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.category-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.category-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.courses-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}.empty-state{text-align:center;padding:80px 24px}.empty-icon{font-size:64px;margin-bottom:16px}.empty-state h3{font-size:20px;color:var(--text-primary);margin-bottom:8px}.empty-state p{color:var(--text-secondary)}.features-section{padding:80px 0}.features-section .section-title{text-align:center;margin-bottom:48px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:24px}.feature-card{padding:32px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;transition:all var(--transition-normal)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent-primary)}.feature-icon{font-size:48px;margin-bottom:16px}.feature-card h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.feature-card p{font-size:14px;color:var(--text-secondary);line-height:1.6}.footer{padding:32px 0;border-top:1px solid var(--border-color)}.footer-content{display:flex;flex-direction:column;align-items:center;gap:16px}.footer-brand{display:flex;align-items:center;gap:12px;font-size:18px;font-weight:700;color:var(--text-primary)}.footer-brand .logo-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--accent-gradient);border-radius:var(--radius-sm);color:#fff}.footer-brand .logo-icon svg{width:18px;height:18px}.footer-logo-img{width:40px;height:40px;object-fit:contain;border-radius:var(--radius-sm);transition:filter var(--transition-fast)}[data-theme=light] .footer-logo-img{filter:brightness(.85) contrast(1.1)}.footer-text{font-size:14px;color:var(--text-tertiary)}.footer-link{color:var(--accent-primary);text-decoration:none;font-weight:500;transition:color .2s ease}.footer-link:hover{color:var(--accent-secondary);text-decoration:underline}@media(max-width:768px){.hero{padding:40px 16px}.hero-stats{flex-direction:column;gap:16px;padding:24px}.stat-divider{width:60px;height:1px}.courses-section{padding:48px 0}.courses-grid{grid-template-columns:1fr}}.note-viewer{padding:32px}.note-content{font-size:16px;line-height:1.8;color:var(--text-primary)}.note-content h1{font-size:28px;font-weight:700;margin:32px 0 16px;color:var(--text-primary)}.note-content h2{font-size:22px;font-weight:600;margin:24px 0 12px;color:var(--text-primary)}.note-content h3{font-size:18px;font-weight:600;margin:20px 0 10px;color:var(--text-primary)}.note-content p{margin-bottom:16px}.note-content strong{font-weight:600;color:var(--text-primary)}.note-content em{font-style:italic}.note-content code{font-family:var(--font-mono);font-size:14px;padding:2px 8px;background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--accent-primary)}.note-content pre{margin:20px 0;padding:20px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);overflow-x:auto}.note-content pre code{padding:0;background:none;border-radius:0;color:var(--text-primary);font-size:14px;line-height:1.6}.note-content ul{margin:16px 0;padding-left:24px}.note-content li{margin-bottom:8px}.note-content li::marker{color:var(--accent-primary)}.document-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:16px;color:var(--text-secondary)}.document-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:16px;text-align:center}.error-icon{font-size:48px}.document-error p{color:var(--text-secondary);font-size:16px}.pdf-viewer{display:flex;flex-direction:column;gap:16px}.pdf-controls{display:flex;align-items:center;justify-content:center;gap:16px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-md);position:sticky;top:0;z-index:10}.page-indicator{font-size:14px;font-weight:500;color:var(--text-secondary);min-width:120px;text-align:center}.pdf-container{display:flex;justify-content:center;overflow-x:auto;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.pdf-container canvas{max-width:100%;height:auto;border-radius:var(--radius-sm);box-shadow:0 4px 16px #0000001a}.document-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:14px;font-weight:500;color:var(--text-secondary);margin-bottom:24px}.word-content{background:var(--bg-card);padding:32px;border-radius:var(--radius-md);border:1px solid var(--border-color)}.word-content img{max-width:100%;height:auto;border-radius:var(--radius-sm);margin:16px 0}.word-content table{width:100%;border-collapse:collapse;margin:16px 0}.word-content th,.word-content td{border:1px solid var(--border-color);padding:12px;text-align:left}.word-content th{background:var(--bg-tertiary);font-weight:600}.document-header{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:16px}.document-header .file-icon{font-size:24px}.document-header .file-name{flex:1;font-size:16px;font-weight:600;color:var(--text-primary)}.document-download{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;text-align:center}.document-download h3{margin:0 0 8px;color:var(--text-primary)}.document-download p{margin:0 0 24px;color:var(--text-secondary)}.word-viewer{display:flex;flex-direction:column;gap:16px}.word-container{background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden}.flashcard-viewer{padding:24px;display:flex;flex-direction:column;align-items:center}.flashcard-empty{padding:48px;text-align:center;color:var(--text-secondary)}.flashcard-header{width:100%;max-width:500px;margin-bottom:32px}.progress-info{display:flex;justify-content:space-between;margin-bottom:8px;font-size:14px;color:var(--text-secondary)}.known-count{color:var(--success)}.progress-bar{height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--accent-gradient);border-radius:var(--radius-full);transition:width var(--transition-normal)}.flashcard-container{perspective:1000px;width:100%;max-width:500px;margin-bottom:32px}.flashcard{position:relative;width:100%;height:300px;cursor:pointer;transform-style:preserve-3d}.flashcard-inner{position:relative;width:100%;height:100%;transition:transform .6s cubic-bezier(.4,0,.2,1);transform-style:preserve-3d}.flashcard.flipped .flashcard-inner{transform:rotateY(180deg)}.flashcard-front,.flashcard-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:var(--radius-xl);display:flex;flex-direction:column;justify-content:center;align-items:center;padding:32px;text-align:center}.flashcard-front{background:var(--bg-card);border:2px solid var(--border-color);box-shadow:var(--shadow-lg)}.flashcard.known .flashcard-front{border-color:var(--success)}.flashcard-back{background:var(--accent-gradient);transform:rotateY(180deg)}.card-content{flex:1;display:flex;flex-direction:column;justify-content:center;width:100%}.card-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:16px;opacity:.7}.flashcard-front .card-label{color:var(--text-secondary)}.flashcard-back .card-label{color:#fffc}.card-content p{font-size:24px;font-weight:600;line-height:1.4;margin:0}.flashcard-front .card-content p{color:var(--text-primary)}.flashcard-back .card-content p{color:#fff}.flip-hint{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-tertiary);margin-top:16px}.flip-hint svg{width:16px;height:16px}.flashcard-controls{display:flex;align-items:center;gap:16px;margin-bottom:16px}.flashcard-controls .btn{display:flex;align-items:center;gap:8px}.flashcard-controls .btn svg{width:20px;height:20px}.btn-known{padding:12px 24px;font-family:inherit;font-size:14px;font-weight:500;color:var(--text-secondary);background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:8px}.btn-known:hover{border-color:var(--success);color:var(--success)}.btn-known.active{background:#10b98126;border-color:var(--success);color:var(--success)}.btn-known svg{width:18px;height:18px}.keyboard-hints{display:flex;gap:24px;font-size:12px;color:var(--text-tertiary);padding:12px 20px;background:var(--bg-tertiary);border-radius:var(--radius-full)}.keyboard-hints span{display:flex;align-items:center;gap:6px}@media(max-width:640px){.flashcard-viewer{padding:16px}.flashcard{height:250px}.card-content p{font-size:20px}.flashcard-controls{flex-wrap:wrap;justify-content:center}.keyboard-hints{display:none}}.quiz-viewer{padding:32px}.quiz-empty{padding:48px;text-align:center;color:var(--text-secondary)}.quiz-progress{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.progress-dots{display:flex;gap:8px;flex-wrap:wrap}.progress-dot{width:12px;height:12px;border-radius:50%;background:var(--bg-tertiary);border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.progress-dot:hover{border-color:var(--accent-primary)}.progress-dot.active{background:var(--accent-primary);border-color:var(--accent-primary);transform:scale(1.2)}.progress-dot.answered{background:var(--success);border-color:var(--success)}.progress-text{font-size:14px;font-weight:500;color:var(--text-secondary)}.question-card{background:var(--bg-secondary);border-radius:var(--radius-lg);padding:32px;margin-bottom:32px}.question-text{font-size:20px;font-weight:600;color:var(--text-primary);margin-bottom:24px;line-height:1.5}.options-list{display:flex;flex-direction:column;gap:12px}.option-btn{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-primary);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.option-btn:hover{border-color:var(--accent-primary);background:var(--bg-tertiary)}.option-btn.selected{border-color:var(--accent-primary);background:#6366f11a}.option-letter{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-sm);font-size:14px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.option-btn.selected .option-letter{background:var(--accent-primary);color:#fff}.option-text{flex:1;font-size:15px;color:var(--text-primary)}.check-icon{width:20px;height:20px;color:var(--accent-primary)}.quiz-controls{display:flex;justify-content:space-between;gap:16px}.quiz-results{text-align:center}.result-circle{width:160px;height:160px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto 32px;border:6px solid}.result-circle.success{border-color:var(--success);background:#10b9811a}.result-circle.warning{border-color:var(--warning);background:#f59e0b1a}.result-circle.fail{border-color:var(--error);background:#ef44441a}.result-score{font-size:40px;font-weight:800;color:var(--text-primary)}.result-label{font-size:14px;color:var(--text-secondary)}.result-stats{display:flex;justify-content:center;gap:48px;margin-bottom:24px}.result-stat{display:flex;flex-direction:column;align-items:center}.stat-number{font-size:28px;font-weight:700}.stat-number.correct{color:var(--success)}.stat-number.wrong{color:var(--error)}.stat-number.total{color:var(--text-primary)}.stat-label{font-size:13px;color:var(--text-secondary)}.result-message{margin-bottom:32px}.result-message p{font-size:18px;color:var(--text-primary)}.answers-review{text-align:left;margin-bottom:32px;padding:24px;background:var(--bg-secondary);border-radius:var(--radius-lg)}.answers-review h4{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:16px}.review-item{padding:16px;border-radius:var(--radius-md);margin-bottom:12px}.review-item.correct{background:#10b9811a;border-left:3px solid var(--success)}.review-item.wrong{background:#ef44441a;border-left:3px solid var(--error)}.review-question{font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.review-number{font-weight:600;margin-right:8px}.review-answers{display:flex;flex-direction:column;gap:4px;font-size:13px}.your-answer{color:var(--text-secondary)}.correct-answer{color:var(--success);font-weight:500}@media(max-width:640px){.quiz-viewer,.question-card{padding:24px 16px}.question-text{font-size:17px}.option-btn{padding:14px 16px}.result-stats{gap:24px}.quiz-controls{flex-direction:column}.quiz-controls .btn{width:100%;justify-content:center}}.video-viewer{padding:0}.video-empty{padding:48px;text-align:center;color:var(--text-secondary)}.video-container{position:relative;width:100%;padding-bottom:56.25%;background:#000}.video-container iframe,.video-container video{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.uploaded-video{object-fit:contain}.video-info{padding:24px;border-top:1px solid var(--border-color)}.video-duration{display:inline-flex;align-items:center;gap:8px;padding:6px 12px;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:13px;color:var(--text-secondary);margin-bottom:16px}.video-duration svg{width:16px;height:16px}.video-description{font-size:15px;color:var(--text-secondary);line-height:1.6}.course-page{display:flex;min-height:calc(100vh - var(--header-height));position:relative}.course-page.resizing{-webkit-user-select:none;user-select:none;cursor:col-resize}.course-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - var(--header-height));gap:16px}.loading-spinner{width:48px;height:48px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.course-mobile-header{display:none;position:fixed;top:var(--header-height);left:0;right:0;height:56px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--border-color);padding:0 16px;align-items:center;gap:12px;z-index:20}.mobile-title{font-size:16px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow:hidden;z-index:30}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color)}.back-link{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:500;color:var(--text-secondary);text-decoration:none;transition:color var(--transition-fast)}.back-link:hover{color:var(--accent-primary)}.back-link svg{width:18px;height:18px}.close-sidebar{display:none}.sidebar-course-info{padding:20px;border-bottom:1px solid var(--border-color)}.course-thumb{width:100%;height:120px;object-fit:cover;border-radius:var(--radius-md);margin-bottom:16px}.course-name{font-size:18px;font-weight:700;color:var(--text-primary);margin-bottom:12px;line-height:1.3}.sidebar-content-list{flex:1;overflow-y:auto;padding:16px}.content-group{margin-bottom:24px}.group-header{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:8px}.group-icon{font-size:16px}.group-title{font-size:13px;font-weight:600;color:var(--text-primary);flex:1}.group-count{font-size:12px;font-weight:500;color:var(--text-tertiary);background:var(--bg-secondary);padding:2px 8px;border-radius:var(--radius-full)}.group-items{display:flex;flex-direction:column;gap:4px}.content-item{display:flex;align-items:center;padding:10px 12px;background:none;border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.content-item:hover{background:var(--bg-tertiary)}.content-items-list{display:flex;flex-direction:column;gap:6px}.content-list-item{display:flex;align-items:center;gap:12px;width:100%;padding:12px 14px;font-family:inherit;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all .2s ease;opacity:.7}.content-list-item:hover:not(.is-selected){opacity:1;background:var(--bg-secondary)}.content-list-item.is-selected{opacity:1;background:var(--accent-primary);border-color:var(--accent-primary);box-shadow:0 4px 16px #6366f166;transform:scale(1.02)}.item-number{width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);border-radius:50%;font-size:12px;font-weight:600;color:var(--text-secondary);flex-shrink:0;transition:all .2s ease}.content-list-item.is-selected .item-number{background:#fff;color:var(--accent-primary)}.item-icon{font-size:18px;flex-shrink:0}.item-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.item-title{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.item-type{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.content-list-item.is-selected .item-title{color:#fff;font-weight:600}.content-list-item.is-selected .item-type{color:#fffc}.empty-sidebar{text-align:center;padding:32px 16px;color:var(--text-tertiary)}.resize-handle{position:fixed;top:var(--header-height);bottom:0;width:8px;cursor:col-resize;z-index:40;display:flex;align-items:center;justify-content:center}.resize-handle:hover .handle-line,.course-page.resizing .handle-line{background:var(--accent-primary);width:4px}.handle-line{width:2px;height:48px;background:var(--border-color);border-radius:var(--radius-full);transition:all var(--transition-fast)}.course-main{flex:1;min-height:calc(100vh - var(--header-height));padding:32px;overflow-y:auto}.content-viewer{max-width:900px;margin:0 auto}.content-header{margin-bottom:32px}.content-meta{margin-bottom:12px}.content-type-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;background:var(--bg-tertiary);border-radius:var(--radius-full);font-size:13px;font-weight:500;color:var(--text-secondary)}.content-title{font-size:28px;font-weight:700;color:var(--text-primary);line-height:1.3}.content-body{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.no-content-selected,.no-viewer{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;text-align:center;padding:48px 24px}.no-content-selected .empty-icon,.no-viewer .empty-icon{font-size:64px;margin-bottom:16px}.no-content-selected h3{font-size:20px;color:var(--text-primary);margin-bottom:8px}.no-content-selected p{color:var(--text-secondary)}.sidebar-overlay{display:none}@media(max-width:768px){.course-mobile-header{display:flex}.course-sidebar{transform:translate(-100%);transition:transform var(--transition-normal);width:85%;max-width:320px;top:0;padding-top:var(--header-height)}.course-sidebar.open{transform:translate(0)}.close-sidebar{display:flex}.resize-handle{display:none}.course-main{margin-left:0!important;padding:72px 16px 16px}.content-title{font-size:22px}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:25}}.content-navigation{display:flex;justify-content:space-between;gap:16px;padding:24px;border-top:1px solid var(--border-color);background:var(--bg-tertiary)}.btn-nav{display:flex;align-items:center;gap:8px;padding:10px 20px;font-weight:600;transition:all .2s ease;border-radius:var(--radius-md);border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary)}.btn-nav:hover:not(:disabled){background:var(--bg-primary);border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-nav:disabled{opacity:.5;cursor:not-allowed;background:var(--bg-tertiary)}.btn-nav svg{width:20px;height:20px}.btn-prev{margin-right:auto}.btn-next{margin-left:auto}@media(max-width:480px){.content-navigation{padding:16px;flex-direction:column;gap:12px}.btn-nav{justify-content:center;width:100%}.btn-prev,.btn-next{margin:0}}.auth-page{min-height:calc(100vh - var(--header-height));display:flex;align-items:center;justify-content:center;padding:48px 24px;background:var(--bg-primary)}.auth-container{width:100%;max-width:440px}.auth-card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:40px;box-shadow:var(--shadow-xl)}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{display:inline-flex;align-items:center;gap:12px;text-decoration:none;color:var(--text-primary);margin-bottom:24px}.auth-logo .logo-img{width:52px;height:52px;object-fit:contain;border-radius:var(--radius-md);transition:filter var(--transition-fast),box-shadow var(--transition-fast)}[data-theme=light] .auth-logo .logo-img{filter:brightness(.85) contrast(1.1);box-shadow:0 2px 8px #0000001a}.auth-logo span{font-size:22px;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-header h1{font-size:28px;font-weight:700;color:var(--text-primary);margin-bottom:8px}.auth-header p{font-size:15px;color:var(--text-secondary)}.auth-error{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#ef44441a;border:1px solid var(--error);border-radius:var(--radius-md);color:var(--error);font-size:14px;margin-bottom:24px}.auth-error svg{width:20px;height:20px;flex-shrink:0}.auth-form{display:flex;flex-direction:column;gap:20px}.btn-full{width:100%}.btn-spinner{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.auth-footer{margin-top:24px;text-align:center}.auth-footer p{font-size:14px;color:var(--text-secondary)}.auth-footer a{color:var(--accent-primary);font-weight:500;text-decoration:none}.auth-footer a:hover{text-decoration:underline}.demo-credentials{margin-top:24px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-md);text-align:center}.demo-credentials p{font-size:12px;color:var(--text-tertiary);margin-bottom:4px}.demo-credentials code{font-family:var(--font-mono);font-size:13px;color:var(--accent-primary)}@media(max-width:640px){.auth-page{padding:24px 16px}.auth-card{padding:32px 24px}.auth-header h1{font-size:24px}}.form-options{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.checkbox-label{display:flex;align-items:center;gap:12px;cursor:pointer;font-size:14px;color:var(--text-secondary);-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.checkbox-label:hover{color:var(--text-primary)}.checkbox-label input[type=checkbox]{display:none}.checkbox-custom{width:22px;height:22px;border:2px solid var(--border-color);border-radius:6px;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.checkbox-custom svg{width:14px;height:14px;stroke:#fff;stroke-width:3;opacity:0;transform:scale(.5);transition:all .2s ease}.checkbox-label input[type=checkbox]:checked+.checkbox-custom{background:var(--accent-gradient);border-color:var(--accent-primary);box-shadow:0 2px 8px #6366f166}.checkbox-label input[type=checkbox]:checked+.checkbox-custom svg{opacity:1;transform:scale(1)}.checkbox-label:hover .checkbox-custom{border-color:var(--accent-primary)}.forgot-link{font-size:14px;font-weight:500;color:var(--accent-primary);text-decoration:none;padding:4px 8px;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.forgot-link:hover{background:#6366f11a;text-decoration:none}.password-requirements{display:flex;flex-direction:column;gap:6px;margin-top:8px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.requirement{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-tertiary);transition:color var(--transition-fast)}.requirement.valid{color:var(--success)}.requirement .indicator{width:16px;text-align:center;font-weight:600}.input-valid{border-color:var(--success)!important}.input-error{border-color:var(--error)!important}.field-error{font-size:12px;color:var(--error);margin-top:4px}.success-state{text-align:center;padding:16px 0}.success-icon{width:80px;height:80px;margin:0 auto 24px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:linear-gradient(135deg,#6366f11a,#8b5cf61a)}.success-icon svg{width:40px;height:40px;stroke:var(--accent-primary)}.success-icon.success{background:linear-gradient(135deg,#10b9811a,#0596691a)}.success-icon.success svg{stroke:var(--success)}.success-state h2{font-size:24px;font-weight:700;color:var(--text-primary);margin-bottom:12px}.success-state>p{font-size:15px;color:var(--text-secondary);line-height:1.6;margin-bottom:24px}.success-tips{text-align:left;padding:20px;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:24px}.success-tips p{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px}.success-tips ul{margin:0;padding-left:20px}.success-tips li{font-size:13px;color:var(--text-secondary);line-height:1.8}.alert{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:var(--radius-md);font-size:14px;margin-bottom:20px}.alert svg{flex-shrink:0}.alert-error{background:#ef44441a;border:1px solid var(--error);color:var(--error)}.alert-success{background:#10b9811a;border:1px solid var(--success);color:var(--success)}.dashboard-page{min-height:calc(100vh - var(--header-height))}.dashboard-container{display:flex;max-width:1400px;margin:0 auto;min-height:calc(100vh - var(--header-height))}.dashboard-sidebar{width:280px;padding:32px 24px;background:var(--bg-secondary);border-right:1px solid var(--border-color);flex-shrink:0}.sidebar-user{text-align:center;margin-bottom:32px}.avatar-upload-wrapper{position:relative;width:80px;height:80px;margin:0 auto 16px;cursor:pointer}.user-avatar-lg{width:80px;height:80px;border-radius:50%;border:3px solid var(--accent-primary);object-fit:cover}.avatar-upload-overlay{position:absolute;inset:0;background:#00000080;border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity var(--transition-fast);color:#fff}.avatar-upload-wrapper:hover .avatar-upload-overlay{opacity:1}.sidebar-user h2{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.user-badges{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.sidebar-nav{display:flex;flex-direction:column;gap:8px}.nav-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:500;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left}.nav-btn svg{width:20px;height:20px}.nav-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-btn.active{background:var(--accent-primary);color:#fff}.dashboard-main{flex:1;padding:32px;overflow-y:auto}.content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px;flex-wrap:wrap;gap:16px}.content-header h1{font-size:28px;font-weight:700;color:var(--text-primary)}.no-permission-badge{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f59e0b1a;border:1px solid var(--warning);border-radius:var(--radius-full);color:var(--warning);font-size:13px;font-weight:500}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px;gap:16px;color:var(--text-secondary)}.courses-list{display:flex;flex-direction:column;gap:16px}.course-item{display:flex;gap:20px;padding:20px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.course-item:hover{border-color:var(--accent-primary)}.course-thumb-sm{width:120px;height:80px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.course-info{flex:1;min-width:0}.course-info h3{font-size:16px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.course-info>p{font-size:14px;color:var(--text-secondary);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-stats{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--text-tertiary);margin-bottom:12px}.course-contents-mini{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--bg-tertiary);border-radius:var(--radius-md);max-height:200px;overflow-y:auto}.content-mini-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:13px;cursor:grab;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;-webkit-user-select:none;user-select:none}.content-mini-item:active{cursor:grabbing;transform:scale(1.02);box-shadow:0 8px 25px #00000026;z-index:10}.content-mini-item:hover{border-color:var(--accent-primary);transform:translate(4px);background:var(--bg-card)}.content-mini-item.dragging{opacity:.7;transform:scale(1.05) rotate(2deg);box-shadow:0 12px 30px #6366f14d;border-color:var(--accent-primary);z-index:100}.content-mini-item.drag-over{border-color:var(--accent-secondary);background:#6366f11a;transform:translateY(4px)}.drag-handle{color:var(--text-tertiary);font-size:14px;-webkit-user-select:none;user-select:none;opacity:.5;transition:opacity .2s ease;flex-shrink:0}.content-mini-item:hover .drag-handle{opacity:1;color:var(--accent-primary)}.content-order-num{width:22px;height:22px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:50%;font-size:11px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.content-type-icon{font-size:16px;flex-shrink:0}.content-mini-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text-primary);font-weight:500}.content-mini-actions{display:flex;gap:4px;opacity:0;transition:opacity .2s ease}.content-mini-item:hover .content-mini-actions{opacity:1}.btn-mini{padding:6px 8px;font-size:12px;background:var(--bg-tertiary);border:none;cursor:pointer;border-radius:var(--radius-sm);transition:all .2s ease}.btn-mini:hover{background:var(--bg-primary);transform:scale(1.1)}.btn-mini-danger:hover{background:#ef444426}.course-actions{display:flex;flex-direction:column;gap:8px;flex-shrink:0}.profile-form{max-width:500px;display:flex;flex-direction:column;gap:20px}.profile-form small{font-size:12px;color:var(--text-tertiary);margin-top:4px}.avatar-edit-area{display:flex;align-items:center;gap:16px}.avatar-preview{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--border-color)}.settings-card{max-width:600px}.settings-card h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.settings-card p{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.theme-options{display:flex;gap:16px;flex-wrap:wrap}.theme-option{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px 24px;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);min-width:120px;font-family:inherit;font-size:14px;color:var(--text-secondary)}.theme-option svg{width:28px;height:28px}.theme-option:hover{border-color:var(--accent-primary);color:var(--text-primary)}.theme-option.active{border-color:var(--accent-primary);background:#6366f11a;color:var(--accent-primary)}.empty-state{text-align:center;padding:60px 24px;background:var(--bg-card);border:1px dashed var(--border-color);border-radius:var(--radius-lg)}.empty-state .empty-icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:8px}.empty-state p{font-size:14px;color:var(--text-secondary);margin-bottom:20px}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;padding:24px;z-index:100;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{width:100%;max-width:480px;max-height:90vh;overflow-y:auto;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl)}.modal-lg{max-width:640px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-secondary);z-index:10}.modal-header h2{font-size:18px;font-weight:600;color:var(--text-primary)}.modal-form{padding:24px;display:flex;flex-direction:column;gap:16px}.modal-form textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:var(--text-primary)}.checkbox-group label{display:flex;align-items:center;gap:10px;cursor:pointer}.checkbox-group input[type=checkbox]{width:18px;height:18px;accent-color:var(--accent-primary)}.upload-area{border:2px dashed var(--border-color);border-radius:var(--radius-md);overflow:hidden}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:32px;cursor:pointer;color:var(--text-tertiary);transition:all var(--transition-fast)}.upload-placeholder:hover{background:var(--bg-tertiary);color:var(--accent-primary);border-color:var(--accent-primary)}.upload-placeholder span{font-size:14px}.upload-placeholder small{font-size:12px}.upload-preview{position:relative;padding:12px;display:flex;flex-direction:column;align-items:center;gap:12px}.upload-preview img{max-width:100%;max-height:150px;border-radius:var(--radius-md)}.video-preview{width:100%}.video-preview video{width:100%;border-radius:var(--radius-md)}.dynamic-list{display:flex;flex-direction:column;gap:12px}.dynamic-item{padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:10px}.dynamic-item-header{display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600;color:var(--text-secondary)}.btn-remove{width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:18px;background:none;border:none;color:var(--error);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast)}.btn-remove:hover{background:#ef44441a}.quiz-options{display:flex;flex-direction:column;gap:8px}.quiz-option{display:flex;align-items:center;gap:10px}.quiz-option input[type=radio]{width:18px;height:18px;accent-color:var(--accent-primary)}.quiz-option .input{flex:1}.form-divider{text-align:center;color:var(--text-tertiary);font-size:13px;position:relative}.form-divider:before,.form-divider:after{content:"";position:absolute;top:50%;width:calc(50% - 20px);height:1px;background:var(--border-color)}.form-divider:before{left:0}.form-divider:after{right:0}.modal-actions{display:flex;gap:12px;justify-content:flex-end;padding-top:8px}@media(max-width:900px){.dashboard-container{flex-direction:column}.dashboard-sidebar{width:100%;border-right:none;border-bottom:1px solid var(--border-color);padding:24px}.sidebar-user{display:flex;align-items:center;gap:16px;text-align:left;margin-bottom:20px}.avatar-upload-wrapper{width:56px;height:56px;margin:0}.user-avatar-lg{width:56px;height:56px}.user-badges{justify-content:flex-start}.sidebar-nav{flex-direction:row;flex-wrap:wrap}.nav-btn{flex:1;min-width:120px;justify-content:center}.dashboard-main{padding:24px 16px}.course-item{flex-direction:column}.course-thumb-sm{width:100%;height:140px}.course-actions{flex-direction:row;flex-wrap:wrap}.course-actions .btn{flex:1;justify-content:center;min-width:100px}}@media(max-width:640px){.content-header{flex-direction:column;align-items:flex-start}.content-header .btn{width:100%;justify-content:center}.theme-options{flex-direction:column}.theme-option{flex-direction:row;min-width:auto;width:100%}.form-row{grid-template-columns:1fr}}.input-mode-toggle{display:flex;gap:8px;margin-top:8px}.mode-btn{flex:1;padding:12px 16px;font-family:inherit;font-size:14px;font-weight:500;background:var(--bg-tertiary);border:2px solid transparent;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .2s ease}.mode-btn:hover{background:var(--bg-secondary);border-color:var(--border-color)}.mode-btn.active{background:#6366f11a;border-color:var(--accent-primary);color:var(--accent-primary)}.upload-progress{padding:20px;display:flex;flex-direction:column;gap:12px}.upload-progress-info{display:flex;justify-content:space-between;align-items:center}.upload-filename{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.upload-speed{font-size:13px;color:var(--accent-primary);font-weight:600}.upload-progress-bar{width:100%;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.upload-progress-fill{height:100%;background:var(--accent-gradient);border-radius:var(--radius-full);transition:width .3s ease}.upload-percent{text-align:center;font-size:20px;font-weight:700;color:var(--accent-primary)}.file-preview{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-tertiary);border-radius:var(--radius-md);margin-bottom:12px}.file-icon{font-size:32px}.file-name{font-size:14px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-page{min-height:calc(100vh - var(--header-height));padding:32px;background:var(--bg-primary)}.admin-container{max-width:1200px;margin:0 auto}.admin-header{margin-bottom:32px}.admin-title h1{font-size:32px;font-weight:700;color:var(--text-primary);margin-bottom:4px}.admin-title p{font-size:15px;color:var(--text-secondary)}.admin-tabs{display:flex;gap:8px;margin-bottom:32px;padding:8px;background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.tab-btn{display:flex;align-items:center;gap:10px;padding:12px 20px;font-family:inherit;font-size:14px;font-weight:500;color:var(--text-secondary);background:none;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.tab-btn svg{width:18px;height:18px}.tab-btn:hover{color:var(--text-primary);background:var(--bg-tertiary)}.tab-btn.active{color:#fff;background:var(--accent-gradient);box-shadow:var(--shadow-md)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:32px}.stat-card{display:flex;align-items:center;gap:16px;padding:24px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);transition:all var(--transition-fast)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:56px;height:56px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.stat-icon svg{width:28px;height:28px;color:#fff}.stat-icon.users{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.stat-icon.courses{background:linear-gradient(135deg,#10b981,#059669)}.stat-icon.contents{background:linear-gradient(135deg,#f59e0b,#d97706)}.stat-icon.public{background:linear-gradient(135deg,#3b82f6,#2563eb)}.stat-info{display:flex;flex-direction:column}.stat-value{font-size:28px;font-weight:700;color:var(--text-primary)}.stat-label{font-size:14px;color:var(--text-secondary)}.content-breakdown h3{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:20px}.breakdown-list{display:flex;flex-direction:column;gap:16px}.breakdown-item{display:flex;align-items:center;gap:16px}.breakdown-label{width:120px;font-size:14px;color:var(--text-secondary);flex-shrink:0}.breakdown-bar{flex:1;height:8px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.breakdown-fill{height:100%;background:var(--accent-gradient);border-radius:var(--radius-full);transition:width var(--transition-normal)}.breakdown-value{width:40px;font-size:14px;font-weight:600;color:var(--text-primary);text-align:right}.data-table{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.data-table table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:16px 20px;text-align:left}.data-table th{background:var(--bg-tertiary);font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.data-table td{border-top:1px solid var(--border-color);font-size:14px;color:var(--text-primary)}.data-table tr:hover td{background:var(--bg-tertiary)}.user-cell,.course-cell{display:flex;align-items:center;gap:12px}.user-cell img{width:36px;height:36px;border-radius:50%}.course-cell img{width:48px;height:32px;object-fit:cover;border-radius:var(--radius-sm)}.table-actions{display:flex;gap:8px}.btn-danger{color:var(--error)}.btn-danger:hover{background:#ef44441a}.permission-toggle{padding:6px 12px;font-family:inherit;font-size:12px;font-weight:500;border:1px solid var(--border-color);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);background:var(--bg-tertiary);color:var(--text-secondary)}.permission-toggle:hover:not(:disabled){border-color:var(--accent-primary)}.permission-toggle.active{background:#10b98126;color:var(--success);border-color:var(--success)}.permission-toggle:disabled{opacity:.5;cursor:not-allowed}@media(max-width:900px){.admin-page{padding:24px 16px}.admin-tabs{flex-wrap:wrap}.tab-btn{flex:1;min-width:100px;justify-content:center}.tab-btn span{display:none}.data-table{overflow-x:auto}.data-table table{min-width:800px}}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}.stat-card{padding:20px}.stat-icon{width:48px;height:48px}.stat-icon svg{width:24px;height:24px}.stat-value{font-size:24px}.tab-btn{min-width:auto;padding:12px 16px}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:0 25px 50px -12px #0006;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.95) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--border-color)}.modal-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center;gap:12px}.modal-header h3:before{content:"🔐";font-size:24px}.modal-close{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:50%;font-size:20px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.modal-close:hover{background:var(--error);border-color:var(--error);color:#fff}.modal-body{padding:28px}.modal-info{font-size:15px;color:var(--text-secondary);margin-bottom:24px;padding:16px;background:var(--bg-tertiary);border-radius:var(--radius-md);border-left:4px solid var(--accent-primary)}.modal-info strong{color:var(--accent-primary);font-weight:600}.modal-body .form-group{margin-bottom:20px}.modal-body .form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.modal-body .input{width:100%;padding:14px 16px;font-size:15px;background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.modal-body .input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 4px #6366f126}.modal-footer{display:flex;gap:12px;padding:20px 28px;border-top:1px solid var(--border-color);background:var(--bg-tertiary);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.modal-footer .btn{flex:1;padding:14px 20px;font-size:15px;font-weight:600;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.modal-footer .btn-secondary{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}.modal-footer .btn-secondary:hover{background:var(--bg-primary);color:var(--text-primary)}.modal-footer .btn-primary{background:var(--accent-gradient);border:none;color:#fff;box-shadow:0 4px 12px #6366f14d}.modal-footer .btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f166}:root{--bg-primary: #f8fafc;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-card: rgba(255, 255, 255, .8);--bg-glass: rgba(255, 255, 255, .7);--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--text-inverse: #ffffff;--accent-primary: #6366f1;--accent-secondary: #8b5cf6;--accent-gradient: linear-gradient(135deg, #6366f1 0%, #8b5cf6 50%, #a855f7 100%);--accent-glow: rgba(99, 102, 241, .3);--border-color: rgba(0, 0, 0, .08);--border-color-strong: rgba(0, 0, 0, .15);--success: #10b981;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .07), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .08), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--sidebar-width: 320px;--header-height: 64px}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: rgba(30, 41, 59, .8);--bg-glass: rgba(30, 41, 59, .7);--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-tertiary: #64748b;--text-inverse: #0f172a;--accent-primary: #818cf8;--accent-secondary: #a78bfa;--accent-gradient: linear-gradient(135deg, #818cf8 0%, #a78bfa 50%, #c084fc 100%);--accent-glow: rgba(129, 140, 248, .3);--border-color: rgba(255, 255, 255, .08);--border-color-strong: rgba(255, 255, 255, .15);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4), 0 2px 4px -1px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5), 0 4px 6px -2px rgba(0, 0, 0, .3);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .5), 0 10px 10px -5px rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--text-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}::selection{background:var(--accent-primary);color:var(--text-inverse)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:14px;font-weight:600;line-height:1;border-radius:var(--radius-md);border:none;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px var(--accent-glow)}.btn-secondary{background:var(--bg-glass);color:var(--text-primary);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--border-color-strong)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-tertiary);color:var(--text-primary)}.btn-icon{padding:10px;border-radius:var(--radius-md)}.btn-sm{padding:8px 16px;font-size:13px}.btn-lg{padding:16px 32px;font-size:16px}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-md);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.input{width:100%;padding:12px 16px;font-family:inherit;font-size:14px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.input::placeholder{color:var(--text-tertiary)}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;font-size:12px;font-weight:500;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-secondary)}.badge-primary{background:#6366f126;color:var(--accent-primary)}.badge-success{background:#10b98126;color:var(--success)}.badge-warning{background:#f59e0b26;color:var(--warning)}.badge-error{background:#ef444426;color:var(--error)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.animate-fade-in{animation:fadeIn .5s ease forwards}.animate-fade-in-up{animation:fadeInUp .5s ease forwards}.animate-fade-in-down{animation:fadeInDown .5s ease forwards}.animate-slide-in-left{animation:slideInLeft .5s ease forwards}.animate-slide-in-right{animation:slideInRight .5s ease forwards}.animate-scale-in{animation:scaleIn .3s ease forwards}.animate-float{animation:float 3s ease-in-out infinite}.stagger-1{animation-delay:.1s}.stagger-2{animation-delay:.2s}.stagger-3{animation-delay:.3s}.stagger-4{animation-delay:.4s}.stagger-5{animation-delay:.5s}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 24px}.text-gradient{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glass{background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}@media(max-width:768px){:root{--header-height: 56px;--sidebar-width: 280px}.container{padding:0 16px}}@media(max-width:640px){.btn{padding:10px 20px;font-size:13px}.btn-lg{padding:14px 28px;font-size:15px}}.app-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px;background:var(--bg-primary);color:var(--text-secondary)}.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dragging{opacity:.5}.drag-over{border-color:var(--accent-primary)!important;background:#6366f10d!important}
