:root{--bg-primary: #0a0e1a;--bg-secondary: #0f172a;--bg-card: rgba(15, 23, 42, .95);--bg-card-hover: rgba(30, 41, 59, .95);--bg-hover: #334155;--bg-input: #0a0e1a;--border: #334155;--border-light: rgba(255, 255, 255, .1);--text-primary: #ffffff;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--accent: #0ea5e9;--accent-hover: #0284c7;--accent-light: #38bdf8;--secondary: #06b6d4;--success: #10b981;--success-bg: rgba(16, 185, 129, .1);--warning: #f59e0b;--danger: #ef4444;--danger-bg: rgba(239, 68, 68, .1);--glass-bg: linear-gradient(135deg, rgba(15, 23, 42, .95), rgba(30, 41, 59, .95));--glass-border: rgba(255, 255, 255, .1);--shadow-glow-cyan: 0 0 20px rgba(14, 165, 233, .4);--shadow-glow-sm: 0 0 10px rgba(14, 165, 233, .2);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 18px;--radius-full: 9999px;--sidebar-width: 260px;--topbar-height: 56px;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Orbitron", var(--font);--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;scroll-behavior:smooth;background-color:#0a0e1a}body{font-family:var(--font);background:#0a0e1a;background-image:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);background-attachment:fixed;color:var(--text-primary);line-height:1.6;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 20% 50%,rgba(14,165,233,.08) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(6,182,212,.06) 0%,transparent 50%);pointer-events:none;z-index:0}#root{position:relative;z-index:1}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}a{color:var(--accent-light);text-decoration:none}a:hover{color:var(--accent)}img{max-width:100%}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-right:1px solid var(--glass-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;transition:transform var(--transition)}.sidebar-header{padding:20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.sidebar-logo{display:flex;align-items:center;gap:10px}.logo-icon{width:36px;height:36px;border-radius:var(--radius-md);background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;color:#fff;box-shadow:var(--shadow-glow-sm)}.logo-text{font-weight:700;font-size:16px}.mobile-close{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer}.sidebar-nav{flex:1;padding:12px;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:var(--radius-md);color:var(--text-secondary);font-size:14px;font-weight:500;cursor:pointer;transition:var(--transition);border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item.nav-active{background:#0ea5e926;color:var(--accent-light)}.nav-badge{margin-left:auto;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:2px 7px;border-radius:10px}.sidebar-footer{padding:12px;border-top:1px solid var(--border)}.user-nav{gap:10px}.user-avatar-small{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}.user-info-small{display:flex;flex-direction:column;overflow:hidden}.user-name-small{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role-small{font-size:11px;color:var(--text-muted)}.logout-btn{color:var(--text-muted)!important;margin-top:4px}.logout-btn:hover{color:var(--danger)!important}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.top-bar{height:var(--topbar-height);background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--glass-border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:50}.mobile-menu-btn{display:none;background:none;border:none;color:var(--text-secondary);cursor:pointer}.top-bar-right{display:flex;align-items:center;gap:12px;margin-left:auto}.notification-btn{position:relative;color:var(--text-secondary);display:flex;align-items:center;padding:8px;border-radius:var(--radius-sm)}.notification-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.notification-badge{position:absolute;top:2px;right:2px;background:var(--danger);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center}.page-content{flex:1;padding:24px;max-width:1200px;width:100%;margin:0 auto}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);width:280px}.sidebar.sidebar-open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:99}.mobile-close,.mobile-menu-btn{display:flex}.main-content{margin-left:0}.page-content{padding:16px}}.page-loader{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:14px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;gap:16px;flex-wrap:wrap}.page-header h1{display:flex;align-items:center;gap:10px;font-size:24px;font-weight:700}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:600;border:none;cursor:pointer;transition:var(--transition);text-decoration:none;font-family:var(--font)}.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent-hover));color:#fff;border:1px solid var(--accent);box-shadow:0 2px 8px #0ea5e933}.btn-primary:hover{background:linear-gradient(135deg,var(--accent-light),var(--accent));box-shadow:var(--shadow-glow-cyan);transform:translateY(-1px);color:#fff}.btn-primary:active{transform:scale(.97)}.btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.btn-success{background:var(--success);color:#fff}.btn-outline{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);color:var(--text-primary);border:1px solid var(--glass-border)}.btn-outline:hover{background:var(--bg-card-hover);border-color:#fff3;transform:translateY(-1px);color:var(--text-primary)}.btn-full{width:100%;justify-content:center}.btn-sm{padding:6px 12px;font-size:12px}.btn-large{padding:14px 28px;font-size:16px}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:var(--font);transition:var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px #0ea5e926,var(--shadow-glow-sm)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-group textarea{resize:vertical;min-height:100px}.form-group select{cursor:pointer}.empty-state{text-align:center;padding:60px 24px;color:var(--text-muted)}.empty-state h3{margin:16px 0 8px;font-size:18px;color:var(--text-secondary)}.empty-state p{margin-bottom:20px}.empty-state-small{text-align:center;padding:24px;color:var(--text-muted);font-size:13px}.progress-bar{height:6px;background:var(--bg-hover);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--secondary));border-radius:3px;transition:width .5s ease;box-shadow:0 0 8px #0ea5e94d}.back-link{display:inline-flex;align-items:center;gap:4px;color:var(--text-secondary);font-size:14px;margin-bottom:16px}.back-link:hover{color:var(--accent-light)}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:24px}.pagination button{padding:8px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:var(--font)}.pagination button:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.pagination button:disabled{opacity:.4;cursor:not-allowed}.pagination span{font-size:14px;color:var(--text-muted)}.role-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;background:#0ea5e926;color:var(--accent-light);text-transform:uppercase}.role-badge.admin{background:#f59e0b26;color:var(--warning)}.role-badge-small{width:18px;height:18px;border-radius:50%;background:var(--warning);color:var(--bg-primary);font-size:10px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.prose{line-height:1.7;color:var(--text-secondary)}.prose h1,.prose h2,.prose h3{color:var(--text-primary);margin:20px 0 10px}.prose p{margin-bottom:12px}.prose ul,.prose ol{padding-left:24px;margin-bottom:12px}.prose code{background:var(--bg-hover);padding:2px 6px;border-radius:4px;font-size:13px}.prose pre{background:var(--bg-primary);padding:16px;border-radius:var(--radius-md);overflow-x:auto;margin-bottom:16px}.prose pre code{background:none;padding:0}.prose blockquote{border-left:3px solid var(--accent);padding-left:16px;color:var(--text-muted);margin:12px 0}.prose a{color:var(--accent-light)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#0a0e1a;background-image:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);position:relative}.auth-page:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at 30% 30%,rgba(14,165,233,.1) 0%,transparent 50%),radial-gradient(circle at 70% 70%,rgba(6,182,212,.08) 0%,transparent 50%);pointer-events:none}.auth-card{width:100%;max-width:420px;background:var(--glass-bg);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-xl);padding:40px 32px;position:relative;z-index:1;box-shadow:0 8px 40px #0006}.auth-header{text-align:center;margin-bottom:32px}.auth-logo{width:56px;height:56px;border-radius:var(--radius-lg);background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:800;font-size:24px;color:#fff;margin:0 auto 16px;box-shadow:var(--shadow-glow-cyan)}.auth-header h1{font-size:22px;font-weight:700;margin-bottom:4px}.auth-header p{color:var(--text-muted);font-size:14px}.auth-form{margin-bottom:20px}.auth-error{padding:10px 14px;background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-md);color:#fca5a5;font-size:13px;margin-bottom:16px}.auth-footer{text-align:center;font-size:14px;color:var(--text-muted)}.success-msg{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--success-bg);border:1px solid rgba(34,197,94,.3);border-radius:var(--radius-md);color:#86efac;font-size:13px;margin-bottom:16px}.dashboard-welcome{margin-bottom:32px}.dashboard-welcome h1{font-size:28px;margin-bottom:4px}.dashboard-subtitle{color:var(--text-muted);font-size:15px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.dashboard-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:24px;color:var(--text-secondary);transition:var(--transition)}.dashboard-card:hover{border-color:var(--accent);color:var(--text-primary);transform:translateY(-2px);box-shadow:var(--shadow-glow-sm)}.dashboard-card h3{margin:12px 0 4px;color:var(--text-primary);font-size:16px}.dashboard-card p{font-size:13px;color:var(--text-muted)}.dashboard-progress{margin-top:12px}.dashboard-progress span{font-size:12px;color:var(--text-muted);display:block;margin-top:6px}.no-access-banner{display:flex;align-items:flex-start;gap:20px;padding:24px;background:#f59e0b0d;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-lg);margin-bottom:24px;color:var(--warning)}.no-access-banner h3{color:var(--text-primary);margin-bottom:4px}.no-access-banner p{color:var(--text-secondary);font-size:14px;margin-bottom:12px}.admin-quick-link{margin-top:24px}.no-access-page{display:flex;align-items:center;justify-content:center;padding:24px}.no-access-content{text-align:center;max-width:700px;width:100%}.no-access-content h1{margin:20px 0 8px;font-size:28px}.no-access-content>p{color:var(--text-muted);margin-bottom:28px}.no-access-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.no-access-help{margin-top:32px;color:var(--text-muted);font-size:14px}.alert{padding:12px 16px;border-radius:var(--radius-md);font-size:14px;margin-bottom:20px}.alert-error{background:var(--danger-bg);border:1px solid rgba(239,68,68,.3);color:#fca5a5}.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:8px;text-align:left}.plan-card{background:var(--glass-bg);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:28px 24px;position:relative;transition:var(--transition)}.plan-card:hover{border-color:#fff3;transform:translateY(-3px);box-shadow:var(--shadow-glow-sm)}.plan-popular{border-color:var(--accent);box-shadow:var(--shadow-glow-sm)}.plan-popular:hover{border-color:var(--accent-light);box-shadow:var(--shadow-glow-cyan)}.plan-badge{position:absolute;top:-10px;right:16px;background:var(--accent);color:#fff;font-size:11px;font-weight:700;padding:3px 12px;border-radius:10px}.plan-card h3{font-size:18px;font-weight:700;margin-bottom:8px}.plan-price{font-size:32px;font-weight:800;margin-bottom:20px;color:var(--accent-light)}.plan-price span{font-size:16px;font-weight:500;color:var(--text-muted)}.plan-features{list-style:none;margin-bottom:24px}.plan-features li{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:14px;color:var(--text-secondary)}.plan-features li svg{color:var(--success);flex-shrink:0}.plan-card .btn{width:100%;justify-content:center}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.payment-status-page{display:flex;align-items:center;justify-content:center;min-height:60vh;padding:24px}.payment-status-content{text-align:center;max-width:480px}.payment-status-content h1{font-size:24px;margin:20px 0 8px}.payment-status-content p{color:var(--text-muted);margin-bottom:24px}.payment-status-content .text-success{color:var(--success)}.payment-status-content .text-error{color:var(--danger)}.payment-status-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.course-card{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);margin-bottom:20px;overflow:hidden}.course-header{padding:24px;border-bottom:1px solid var(--border)}.course-header h2{font-size:20px;margin-bottom:4px}.course-header p{color:var(--text-muted);font-size:14px}.course-progress{margin-top:12px}.course-progress span{display:block;font-size:12px;color:var(--text-muted);margin-top:6px}.module-item{border-bottom:1px solid var(--border)}.module-item:last-child{border-bottom:none}.module-header{display:flex;align-items:center;gap:10px;padding:14px 20px;width:100%;background:none;border:none;color:var(--text-primary);font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.module-header:hover{background:var(--bg-hover)}.module-title{flex:1;text-align:left}.module-count{color:var(--text-muted);font-size:12px;font-weight:500}.lessons-list{padding:4px 0}.lesson-item{display:flex;align-items:center;gap:12px;padding:10px 20px 10px 48px;color:var(--text-secondary);font-size:14px;transition:var(--transition)}.lesson-item:hover{background:var(--bg-hover);color:var(--text-primary)}.lesson-item.lesson-completed{color:var(--text-muted)}.lesson-item.lesson-completed .lesson-status{color:var(--success)}.lesson-status{flex-shrink:0;color:var(--text-muted)}.lesson-title{flex:1}.lesson-duration{font-size:12px;color:var(--text-muted)}.lesson-breadcrumb{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);margin-bottom:20px;flex-wrap:wrap}.lesson-breadcrumb a{color:var(--accent-light)}.lesson-content-wrapper{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:32px}.lesson-title{font-size:24px;margin-bottom:24px}.lesson-video{margin-bottom:24px;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:16/9}.lesson-video iframe{width:100%;height:100%}.lesson-content{margin-bottom:32px}.lesson-actions{margin-bottom:24px}.lesson-nav{display:flex;justify-content:space-between;padding-top:20px;border-top:1px solid var(--border)}.lesson-nav-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:var(--bg-hover);border-radius:var(--radius-md);color:var(--text-secondary);font-size:13px}.lesson-nav-btn:hover{color:var(--accent-light)}.forum-categories-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.category-chip{padding:6px 14px;border-radius:20px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:var(--font);transition:var(--transition)}.category-chip:hover{border-color:var(--accent);color:var(--accent-light)}.category-chip.active{background:#0ea5e926;border-color:var(--accent);color:var(--accent-light)}.chip-count{font-size:11px;color:var(--text-muted);margin-left:4px}.forum-toolbar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}.forum-search{display:flex;align-items:center;gap:8px;flex:1;min-width:200px;padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted)}.forum-search input{flex:1;background:none;border:none;color:var(--text-primary);font-size:14px;font-family:var(--font);outline:none}.forum-sort{display:flex;gap:4px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px}.forum-sort button{padding:6px 14px;border:none;background:none;color:var(--text-muted);font-size:13px;font-family:var(--font);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.forum-sort button.active{background:var(--bg-hover);color:var(--text-primary)}.forum-topics-list{display:flex;flex-direction:column;gap:8px}.topic-card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 20px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--text-primary);transition:var(--transition)}.topic-card:hover{border-color:var(--accent);color:var(--text-primary);box-shadow:var(--shadow-glow-sm)}.topic-main{flex:1;min-width:0}.topic-meta-top{display:flex;gap:8px;margin-bottom:4px;align-items:center;flex-wrap:wrap}.topic-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:10px;text-transform:uppercase}.badge-pinned{background:#0ea5e926;color:var(--accent-light)}.badge-locked{background:#f59e0b26;color:var(--warning)}.topic-category{font-size:11px;color:var(--text-muted);background:var(--bg-hover);padding:2px 8px;border-radius:10px}.topic-title{font-size:15px;font-weight:600;margin-bottom:6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topic-meta{display:flex;gap:12px;font-size:12px;color:var(--text-muted);align-items:center}.topic-author{display:flex;align-items:center;gap:6px}.avatar-tiny{width:20px;height:20px;border-radius:50%;background:var(--bg-hover);display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text-secondary)}.topic-stats{display:flex;gap:12px;flex-shrink:0;font-size:13px;color:var(--text-muted)}.topic-stats span{display:flex;align-items:center;gap:4px}.topic-detail{background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:28px;margin-bottom:24px}.topic-detail-header{margin-bottom:20px}.topic-detail-header h1{font-size:22px;margin:8px 0}.topic-author-info{display:flex;align-items:center;gap:8px;font-size:14px}.avatar-small{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--secondary));display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}.author-name{font-weight:600}.topic-time{color:var(--text-muted);font-size:12px}.topic-body{margin-bottom:16px}.topic-actions-bar{display:flex;gap:8px;padding-top:16px;border-top:1px solid var(--border)}.react-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;cursor:pointer;font-family:var(--font);transition:var(--transition)}.react-btn:hover{border-color:var(--accent);color:var(--accent-light)}.react-btn.react-active{border-color:var(--accent);color:var(--accent-light);background:#0ea5e91a}.react-btn.react-danger:hover{border-color:var(--danger);color:var(--danger);background:var(--danger-bg)}.edit-inline-form{margin-top:12px}.edit-inline-form .form-group{margin-bottom:12px}.edit-form-actions{display:flex;gap:8px}.edit-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px;margin-left:auto}.edit-btn:hover{color:var(--accent-light);background:#0ea5e91a}.edit-btn+.delete-btn{margin-left:0}.replies-section{margin-bottom:24px}.replies-section h2{font-size:18px;margin-bottom:16px}.reply-card{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-md);padding:16px 20px;margin-bottom:12px}.reply-header{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:13px}.reply-time{color:var(--text-muted);font-size:12px}.reply-body{margin-bottom:10px}.reply-actions{display:flex;gap:8px}.delete-btn{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:4px}.delete-btn:hover{color:var(--danger);background:var(--danger-bg)}.reply-form{background:var(--glass-bg);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:20px}.reply-form textarea{width:100%;padding:12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font);font-size:14px;resize:vertical;margin-bottom:12px;outline:none}.reply-form textarea:focus{border-color:var(--accent)}.topic-locked-notice{display:flex;align-items:center;gap:8px;padding:16px;color:var(--text-muted);font-size:14px}.new-topic-page h1{font-size:22px;margin-bottom:20px}.topic-form{max-width:700px}.chat-page{display:flex;height:calc(100vh - var(--topbar-height) - 48px);background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);overflow:hidden;position:relative}.chat-mobile-toggle{display:none;position:absolute;top:12px;left:12px;z-index:10;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-secondary);padding:6px 8px;cursor:pointer}.chat-mobile-toggle:hover{color:var(--text-primary)}.chat-sidebar{width:240px;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;background:var(--bg-card)}.chat-sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}.chat-sidebar-header h3{font-size:14px;font-weight:600}.chat-sidebar-actions{display:flex;align-items:center;gap:8px}.online-count{font-size:12px;color:var(--success);display:flex;align-items:center;gap:5px;font-weight:500}.online-dot{width:7px;height:7px;border-radius:50%;background:var(--success);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.chat-mobile-close-btn{display:none;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px}.channels-list{flex:1;overflow-y:auto;padding:6px}.channel-item{display:flex;flex-direction:column;gap:2px;padding:8px 12px;border-radius:var(--radius-sm);background:none;border:none;color:var(--text-secondary);font-size:13px;font-family:var(--font);cursor:pointer;width:100%;text-align:left;transition:var(--transition);margin-bottom:2px}.channel-item:hover{background:var(--bg-hover);color:var(--text-primary)}.channel-item.active{background:#0ea5e926;color:var(--accent-light)}.channel-item.has-unread{color:var(--text-primary);font-weight:500}.channel-item-row{display:flex;align-items:center;gap:6px}.channel-icon{display:flex;align-items:center;flex-shrink:0}.channel-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-unread-badge{background:var(--accent);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 5px;flex-shrink:0}.channel-last-msg{font-size:11px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;padding-left:22px;font-weight:400}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}.chat-connection-banner{display:flex;align-items:center;gap:8px;padding:8px 16px;background:#f59e0b1a;border-bottom:1px solid rgba(245,158,11,.2);color:var(--warning);font-size:13px;font-weight:500}.chat-header{padding:12px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-shrink:0}.chat-header-info{display:flex;align-items:center;gap:8px;font-weight:600;font-size:15px;min-width:0}.chat-header-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-type-tag{font-size:10px;font-weight:600;padding:2px 8px;border-radius:10px;background:#0ea5e91f;color:var(--accent-light);text-transform:uppercase;flex-shrink:0}.chat-online-toggle{display:flex;align-items:center;gap:6px;padding:6px 10px;background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-size:13px;font-family:var(--font);cursor:pointer;transition:var(--transition);flex-shrink:0}.chat-online-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}.chat-online-toggle.active{background:#0ea5e91a;border-color:var(--accent);color:var(--accent-light)}.chat-online-panel{border-bottom:1px solid var(--border);background:#0f172a80;max-height:200px;overflow:hidden;display:flex;flex-direction:column;animation:slideDown .15s ease-out}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:200px;opacity:1}}.chat-online-header{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border)}.chat-online-header button{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex}.chat-online-header button:hover{color:var(--text-primary)}.chat-online-list{overflow-y:auto;padding:8px 12px;display:flex;flex-wrap:wrap;gap:6px}.chat-online-user{display:flex;align-items:center;gap:6px;padding:4px 10px 4px 4px;background:var(--bg-hover);border-radius:20px;font-size:12px}.chat-online-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10px;color:#fff;flex-shrink:0}.chat-online-name{font-weight:500;color:var(--text-primary)}.chat-online-you{color:var(--text-muted);font-size:11px}.chat-online-empty{font-size:12px;color:var(--text-muted);padding:8px}.messages-container{flex:1;overflow-y:auto;padding:16px;scroll-behavior:smooth}.chat-load-more{text-align:center;padding:8px 0 16px}.chat-load-more button{display:inline-flex;align-items:center;gap:6px;padding:6px 16px;background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-secondary);font-size:12px;font-family:var(--font);cursor:pointer;transition:var(--transition)}.chat-load-more button:hover:not(:disabled){background:var(--bg-card);border-color:var(--accent);color:var(--accent-light)}.chat-load-more button:disabled{opacity:.5;cursor:not-allowed}.chat-empty-messages{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;min-height:300px;color:var(--text-muted)}.chat-empty-messages h4{font-size:16px;color:var(--text-secondary)}.chat-empty-messages p{font-size:13px}.chat-date-separator{display:flex;align-items:center;gap:12px;margin:16px 0 12px}.chat-date-separator:before,.chat-date-separator:after{content:"";flex:1;height:1px;background:var(--border)}.chat-date-separator span{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.03em;white-space:nowrap}.message{display:flex;gap:10px;margin-bottom:8px;padding:4px 8px;border-radius:var(--radius-sm);transition:background var(--transition)}.message:hover{background:#ffffff05}.message:hover .message-delete-btn{opacity:1}.message-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--text-secondary);flex-shrink:0;margin-top:2px}.message-own .message-avatar{background:linear-gradient(135deg,var(--accent),var(--secondary));color:#fff}.message-body{flex:1;min-width:0}.message-header{display:flex;align-items:center;gap:6px;margin-bottom:2px}.message-author{font-weight:600;font-size:13px}.message-own .message-author{color:var(--accent-light)}.message-time{font-size:11px;color:var(--text-muted)}.message-delete-btn{opacity:0;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px 4px;border-radius:3px;transition:var(--transition);margin-left:auto;display:flex;align-items:center}.message-delete-btn:hover{color:var(--danger);background:var(--danger-bg)}.message-text{font-size:14px;color:var(--text-secondary);line-height:1.5;white-space:pre-wrap;word-break:break-word}.typing-indicator{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);font-style:italic;padding:4px 8px}.typing-dots{display:flex;gap:3px}.typing-dots span{width:5px;height:5px;border-radius:50%;background:var(--text-muted);animation:typingBounce 1.4s infinite}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typingBounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.chat-input-form{display:flex;gap:8px;padding:12px 16px;border-top:1px solid var(--border);flex-shrink:0}.chat-input-form input{flex:1;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font);font-size:14px;outline:none;transition:border-color var(--transition)}.chat-input-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #0ea5e91a}.chat-input-form input:disabled{opacity:.5}.chat-input-form button{padding:10px 16px;background:var(--accent);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:var(--transition);display:flex;align-items:center}.chat-input-form button:hover:not(:disabled){background:var(--accent-hover)}.chat-input-form button:disabled{opacity:.4;cursor:not-allowed}.chat-sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:19}@media(max-width:768px){.chat-sidebar{width:200px}.chat-page{height:calc(100vh - var(--topbar-height) - 32px)}.chat-header{padding:12px 16px 12px 48px}}@media(max-width:600px){.chat-mobile-toggle,.chat-mobile-close-btn{display:flex}.chat-header{padding:12px 16px 12px 52px}.chat-sidebar{position:absolute;top:0;left:0;bottom:0;z-index:20;transform:translate(-100%);transition:transform .2s ease;box-shadow:none;width:260px}.chat-sidebar.chat-sidebar-mobile-open{transform:translate(0);box-shadow:4px 0 24px #0000004d}.chat-sidebar-overlay{display:block}}.profile-page h1{font-size:22px;margin-bottom:20px}.profile-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px}.profile-tabs button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;color:var(--text-muted);font-size:14px;font-family:var(--font);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);position:relative}.profile-tabs button.active{background:var(--bg-hover);color:var(--text-primary)}.tab-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:1px 6px;border-radius:10px}.profile-form{max-width:480px}.notifications-list{display:flex;flex-direction:column;gap:8px}.notification-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);font-size:14px}.notification-item.unread{border-color:var(--accent);background:#0ea5e90d}.notification-time{font-size:12px;color:var(--text-muted);flex-shrink:0}.admin-page h1{display:flex;align-items:center;gap:10px;font-size:24px;margin-bottom:20px}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:4px;flex-wrap:wrap}.admin-tabs button{display:flex;align-items:center;gap:6px;padding:8px 16px;background:none;border:none;color:var(--text-muted);font-size:14px;font-family:var(--font);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.admin-tabs button.active{background:var(--bg-hover);color:var(--text-primary)}.admin-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.stat-card{display:flex;align-items:center;gap:16px;padding:20px;background:var(--glass-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-md);color:var(--accent-light)}.stat-num{display:block;font-size:28px;font-weight:800;color:var(--text-primary)}.stat-label{display:block;font-size:13px;color:var(--text-muted)}.stat-detail{display:block;font-size:12px;color:var(--text-muted);margin-top:4px}.admin-table{width:100%;border-collapse:collapse;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.admin-table th,.admin-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border);font-size:13px}.admin-table th{background:var(--bg-hover);font-weight:600;color:var(--text-secondary);font-size:12px;text-transform:uppercase;letter-spacing:.05em}.actions-cell{display:flex;gap:6px}.admin-inline-form{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.admin-inline-form input{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:13px}.admin-inline-form input:focus{outline:none;border-color:var(--accent)}.admin-list{display:flex;flex-direction:column;gap:6px}.admin-list-item{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px}.admin-list-item small{color:var(--text-muted)}.admin-forum h3,.admin-chat h3{font-size:16px;margin-bottom:16px}.admin-content-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.admin-content-header h3{display:flex;align-items:center;gap:8px;font-size:16px;font-weight:600}.content-tree{display:flex;flex-direction:column;gap:8px}.content-tree-course{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.content-tree-header{display:flex;align-items:center;gap:8px;padding:10px 14px;transition:var(--transition)}.content-tree-header:hover{background:var(--bg-hover)}.content-tree-header.course-level{padding:14px 16px}.content-tree-header.module-level{padding:10px 16px 10px 24px}.content-tree-header.lesson-level{padding:8px 16px 8px 44px}.tree-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;flex-shrink:0}.tree-toggle:hover{color:var(--text-primary)}.tree-info{flex:1;display:flex;align-items:center;gap:8px;cursor:pointer;min-width:0}.tree-title{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-level .tree-title{font-size:15px}.tree-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);flex-shrink:0}.tree-badges{display:flex;gap:6px;flex-shrink:0}.publish-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:11px;font-weight:600;border:none;cursor:pointer;font-family:var(--font);transition:var(--transition)}.publish-badge.published{background:var(--success-bg);color:var(--success);border:1px solid rgba(34,197,94,.2)}.publish-badge.published:hover{background:#22c55e33}.publish-badge.draft{background:#f59e0b1a;color:var(--warning);border:1px solid rgba(245,158,11,.2)}.publish-badge.draft:hover{background:#f59e0b33}.tree-actions{display:flex;gap:4px;flex-shrink:0;opacity:0;transition:opacity var(--transition)}.content-tree-header:hover .tree-actions{opacity:1}.icon-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:none;border:1px solid transparent;color:var(--text-muted);cursor:pointer;transition:var(--transition)}.icon-btn:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.icon-btn.danger:hover{color:var(--danger);background:var(--danger-bg);border-color:#ef44444d}.tree-drag{display:flex;flex-direction:column;gap:0;flex-shrink:0}.order-btn{display:flex;align-items:center;justify-content:center;width:18px;height:14px;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:8px;line-height:1;padding:0;transition:var(--transition)}.order-btn:hover{color:var(--accent-light)}.content-tree-children{border-top:1px solid var(--border)}.content-tree-module{border-bottom:1px solid var(--border)}.content-tree-module:last-child{border-bottom:none}.content-tree-module .content-tree-children{border-top:1px solid rgba(51,65,85,.4);background:#0f172a4d}.tree-empty{padding:12px 16px 12px 64px;font-size:13px;color:var(--text-muted)}.text-btn{background:none;border:none;color:var(--accent-light);cursor:pointer;font-family:var(--font);font-size:13px;padding:0}.text-btn:hover{text-decoration:underline}.tree-add-row{padding:10px 16px 10px 24px}.lesson-icon{flex-shrink:0;color:var(--text-muted)}.admin-content-editor{max-width:1100px}.admin-content-editor h3{font-size:18px;margin-bottom:20px}.editor-form{max-width:600px}.editor-actions{display:flex;gap:12px;margin-top:8px}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer;accent-color:var(--accent)}.lesson-editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.lesson-editor-header h3{margin-bottom:0}.lesson-editor-header-actions{display:flex;gap:8px}.lesson-editor-grid{display:grid;grid-template-columns:1fr;gap:24px}.lesson-editor-grid:has(.lesson-editor-preview){grid-template-columns:1fr 1fr}.lesson-editor-form{min-width:0}.lesson-meta-row{display:flex;gap:12px;flex-wrap:wrap}.lesson-meta-row .form-group{flex:1;min-width:140px}.markdown-editor{font-family:JetBrains Mono,Fira Code,Cascadia Code,monospace!important;font-size:13px!important;line-height:1.6!important;min-height:400px!important;resize:vertical;-moz-tab-size:2;tab-size:2}.lesson-editor-preview{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;max-height:calc(100vh - 200px);overflow-y:auto;position:sticky;top:calc(var(--topbar-height) + 24px)}.preview-header{display:flex;align-items:center;gap:6px;padding:10px 16px;background:var(--bg-hover);border-bottom:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;position:sticky;top:0;z-index:1}.preview-content{padding:24px}.preview-content h1{font-size:22px;margin-bottom:16px}.preview-video{margin-bottom:20px;border-radius:var(--radius-md);overflow:hidden;aspect-ratio:16/9}.preview-video iframe{width:100%;height:100%}.preview-empty{color:var(--text-muted);font-style:italic;font-size:14px}@media(max-width:900px){.lesson-editor-grid:has(.lesson-editor-preview){grid-template-columns:1fr}.lesson-editor-preview{position:static;max-height:500px}}@media(max-width:768px){.content-tree-header.module-level{padding-left:12px}.content-tree-header.lesson-level{padding-left:24px}.tree-actions{opacity:1}.lesson-meta-row{flex-direction:column}.lesson-meta-row .form-group{max-width:none!important}}.admin-stats-weekly{display:flex;align-items:center;gap:16px;padding:16px 20px;background:#0ea5e90f;border:1px solid rgba(14,165,233,.15);border-radius:var(--radius-md);margin-top:16px;color:var(--accent-light)}.weekly-content strong{display:block;font-size:14px;margin-bottom:4px;color:var(--text-primary)}.weekly-items{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text-secondary)}.stat-danger{color:var(--danger)!important}.admin-chart-card{margin-top:20px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px}.admin-chart-card h3{display:flex;align-items:center;gap:8px;font-size:15px;font-weight:600;margin-bottom:16px}.chart-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.chart-card-header h3{margin-bottom:0}.bar-chart{display:flex;align-items:flex-end;gap:2px;height:140px;padding-top:20px}.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%;min-width:0;position:relative}.bar-value{font-size:10px;color:var(--text-muted);margin-bottom:4px;font-weight:600}.bar-fill{width:100%;max-width:24px;background:linear-gradient(180deg,var(--accent),var(--secondary));border-radius:3px 3px 0 0;min-height:2px;transition:height .5s ease}.bar-label{font-size:9px;color:var(--text-muted);margin-top:4px}.top-users-list{display:flex;flex-direction:column;gap:6px}.top-user-item{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--radius-sm);transition:var(--transition)}.top-user-item:hover{background:var(--bg-hover)}.top-user-rank{font-size:12px;font-weight:700;color:var(--text-muted);min-width:24px}.top-user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;flex-shrink:0}.top-user-info{flex:1;min-width:0}.top-user-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px}.top-user-stats{font-size:12px;color:var(--text-muted)}.top-user-total{font-size:18px;font-weight:800;color:var(--accent-light);min-width:32px;text-align:right}.student-progress-list{display:flex;flex-direction:column;gap:10px;max-height:400px;overflow-y:auto}.student-progress-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-sm);background:#0f172a4d}.student-progress-avatar{width:32px;height:32px;border-radius:50%;background:var(--bg-hover);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:var(--text-secondary);flex-shrink:0}.student-progress-info{flex:1;min-width:0}.student-progress-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:13px;margin-bottom:6px}.plan-tag{font-size:10px;font-weight:700;padding:1px 6px;border-radius:8px;text-transform:uppercase}.plan-tag.base{background:#0ea5e926;color:var(--accent-light)}.plan-tag.pro{background:#06b6d426;color:var(--secondary)}.student-progress-bar-wrapper{display:flex;align-items:center;gap:8px}.student-progress-bar-wrapper .progress-bar{flex:1}.student-progress-pct{font-size:12px;font-weight:700;color:var(--accent-light);min-width:36px;text-align:right}.student-progress-detail{font-size:11px;color:var(--text-muted);margin-top:2px;display:block}.admin-users-toolbar{display:flex;gap:12px;margin-bottom:16px;flex-wrap:wrap;align-items:center}.admin-search-box{display:flex;align-items:center;gap:8px;flex:1;min-width:200px;padding:8px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-muted)}.admin-search-box input{flex:1;background:none;border:none;color:var(--text-primary);font-size:14px;font-family:var(--font);outline:none}.admin-search-clear{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:2px;display:flex;align-items:center}.admin-search-clear:hover{color:var(--text-primary)}.admin-filters{display:flex;gap:8px;align-items:center}.admin-filters select{padding:8px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:13px;cursor:pointer}.admin-filters select:focus{outline:none;border-color:var(--accent)}.admin-users-list{display:flex;flex-direction:column;gap:6px}.admin-user-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:var(--transition)}.admin-user-card.expanded{border-color:var(--accent)}.admin-user-card.blocked{border-color:#ef444440;background:#ef444408}.admin-user-row{display:flex;align-items:center;gap:12px;padding:12px 16px;cursor:pointer;transition:var(--transition)}.admin-user-row:hover{background:var(--bg-hover)}.admin-user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;color:#fff;flex-shrink:0;position:relative}.blocked-indicator{position:absolute;bottom:-2px;right:-2px;width:16px;height:16px;background:var(--danger);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;border:2px solid var(--bg-card)}.admin-user-info{flex:1;min-width:0}.admin-user-name{display:flex;align-items:center;gap:6px;font-weight:600;font-size:14px;margin-bottom:2px}.blocked-badge{font-size:10px;font-weight:600;padding:1px 6px;border-radius:8px;background:var(--danger-bg);color:var(--danger);border:1px solid rgba(239,68,68,.2)}.admin-user-email{font-size:12px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-user-sub{flex-shrink:0}.sub-badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:12px}.sub-badge.active{background:var(--success-bg);color:var(--success);border:1px solid rgba(34,197,94,.2)}.sub-badge.expired{background:#f59e0b1a;color:var(--warning);border:1px solid rgba(245,158,11,.2)}.sub-badge.none{background:var(--bg-hover);color:var(--text-muted);border:1px solid var(--border)}.admin-user-activity{display:flex;gap:10px;flex-shrink:0}.admin-user-activity span{display:flex;align-items:center;gap:3px;font-size:12px;color:var(--text-muted)}.admin-user-expand{color:var(--text-muted);flex-shrink:0}.admin-user-detail{border-top:1px solid var(--border);padding:16px;background:#0f172a4d}.admin-user-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:16px}.admin-user-detail-section h4{font-size:13px;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;border-bottom:1px solid rgba(51,65,85,.3)}.detail-label{color:var(--text-muted)}.detail-recent{margin-top:12px}.detail-recent h5{font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:6px}.detail-recent-item{display:flex;justify-content:space-between;align-items:center;padding:4px 0;font-size:12px}.detail-recent-item span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1;margin-right:8px}.detail-recent-item small{color:var(--text-muted);flex-shrink:0}.admin-user-actions{display:flex;gap:8px;flex-wrap:wrap;padding-top:12px;border-top:1px solid rgba(51,65,85,.3)}.btn-warn{color:var(--warning)!important;border-color:#f59e0b4d!important}.btn-warn:hover{background:#f59e0b1a!important}.btn-danger-outline{background:transparent;color:var(--danger);border:1px solid rgba(239,68,68,.3)}.btn-danger-outline:hover{background:var(--danger-bg)}.admin-forum-subtabs{display:flex;gap:4px;margin-bottom:16px;background:#0f172a66;border:1px solid var(--border);border-radius:var(--radius-sm);padding:3px;width:fit-content}.admin-forum-subtabs button{display:flex;align-items:center;gap:6px;padding:6px 14px;background:none;border:none;color:var(--text-muted);font-size:13px;font-family:var(--font);font-weight:500;cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition)}.admin-forum-subtabs button.active{background:var(--bg-hover);color:var(--text-primary)}.admin-forum-subtabs button:hover:not(.active){color:var(--text-secondary)}.admin-topics-list{display:flex;flex-direction:column;gap:6px}.admin-topic-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:var(--transition)}.admin-topic-card:hover{border-color:var(--border-light)}.admin-topic-main{flex:1;min-width:0}.admin-topic-badges{display:flex;gap:6px;margin-bottom:4px;flex-wrap:wrap}.admin-topic-title{font-size:14px;font-weight:600;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-topic-meta{display:flex;gap:12px;font-size:12px;color:var(--text-muted);align-items:center}.admin-topic-meta span{display:flex;align-items:center;gap:4px}.admin-topic-actions{display:flex;gap:4px;flex-shrink:0}.icon-btn.active{color:var(--accent-light);background:#0ea5e91a;border-color:#0ea5e94d}.admin-cat-item{margin-bottom:6px}.admin-cat-edit{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--bg-card);border:1px solid var(--accent);border-radius:var(--radius-sm)}.admin-cat-edit input{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:13px}.admin-cat-edit input:focus{outline:none;border-color:var(--accent)}.admin-cat-edit-actions{display:flex;gap:8px}.admin-cat-actions,.admin-list-item .admin-cat-actions{display:flex;gap:4px}.admin-inline-form select{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font);font-size:13px;cursor:pointer}.admin-inline-form select:focus{outline:none;border-color:var(--accent)}.subscription-tab{max-width:600px}.sub-info-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px}.sub-info-card.sub-active{border-color:#22c55e4d}.sub-info-card.sub-active .sub-info-header svg:first-child{color:var(--success)}.sub-info-card.sub-expiring{border-color:#f59e0b4d}.sub-info-card.sub-expiring .sub-info-header svg:first-child{color:var(--warning)}.sub-info-card.sub-expired{border-color:#ef444433}.sub-info-card.sub-expired .sub-info-header svg:first-child{color:var(--danger)}.sub-info-card.sub-none{border-color:var(--border)}.sub-info-card.sub-none .sub-info-header svg:first-child{color:var(--text-muted)}.sub-info-header{display:flex;align-items:center;gap:14px}.sub-info-header h3{font-size:18px;font-weight:700;margin-bottom:2px}.sub-info-header p{font-size:14px;color:var(--text-muted)}.sub-info-header .plan-tag{margin-left:auto;font-size:12px;padding:3px 10px}.sub-info-details{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.sub-detail-item{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.sub-detail-item svg{color:var(--text-muted);flex-shrink:0}.sub-detail-item.expiring-warning{color:var(--warning)}.sub-detail-item.expiring-warning svg{color:var(--warning)}.sub-expiry-banner{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;background:#f59e0b14;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-md);color:var(--warning);font-size:13px}.sub-features{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px}.sub-features h4{font-size:14px;font-weight:600;margin-bottom:12px;color:var(--text-secondary)}.sub-features ul{list-style:none}.sub-features li{display:flex;align-items:center;gap:8px;padding:6px 0;font-size:14px;color:var(--text-secondary)}.sub-features li svg{color:var(--success);flex-shrink:0}.dashboard-sub-bar{display:flex;align-items:center;gap:8px;padding:10px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:20px;font-size:13px;color:var(--text-secondary)}.dashboard-sub-bar svg{color:var(--accent-light);flex-shrink:0}.dashboard-sub-sep{color:var(--border-light);margin:0 2px}.text-warning{color:var(--warning)!important;font-weight:600}.sub-expiry-dashboard-banner{display:flex;align-items:center;gap:14px;padding:16px 20px;background:#f59e0b0f;border:1px solid rgba(245,158,11,.2);border-radius:var(--radius-lg);margin-bottom:20px;color:var(--warning)}.sub-expiry-dashboard-banner strong{display:block;font-size:14px;color:var(--text-primary);margin-bottom:2px}.sub-expiry-dashboard-banner p{font-size:13px;color:var(--text-secondary);margin:0}.sub-expiry-dashboard-banner .btn{margin-left:auto;flex-shrink:0}.admin-payments-list{display:flex;flex-direction:column;gap:8px}.admin-payment-item{display:flex;align-items:center;gap:16px;padding:12px 14px;background:#0f172a4d;border-radius:var(--radius-sm);transition:var(--transition)}.admin-payment-item:hover{background:var(--bg-hover)}.admin-payment-user{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.admin-payment-info{display:flex;align-items:center;gap:8px;flex-shrink:0}.admin-payment-dates{display:flex;flex-direction:column;gap:2px;flex-shrink:0;text-align:right}.admin-payment-dates span{display:flex;align-items:center;gap:4px;justify-content:flex-end}@media(max-width:768px){.admin-payment-item{flex-direction:column;align-items:flex-start;gap:8px}.admin-payment-dates{text-align:left}.admin-payment-dates span{justify-content:flex-start}.sub-expiry-dashboard-banner{flex-direction:column;align-items:flex-start}.sub-expiry-dashboard-banner .btn{margin-left:0}.dashboard-sub-bar{flex-wrap:wrap}}@media(max-width:900px){.admin-user-detail-grid{grid-template-columns:1fr}}@media(max-width:768px){.admin-user-row{flex-wrap:wrap;gap:8px}.admin-user-sub{order:5;width:100%}.admin-user-activity{order:4;width:100%}.admin-users-toolbar{flex-direction:column}.admin-filters{width:100%;flex-wrap:wrap}.admin-filters select{flex:1;min-width:120px}.admin-topic-card{flex-direction:column;align-items:flex-start}.admin-topic-actions{width:100%;justify-content:flex-end}.bar-chart{height:100px}.weekly-items{flex-direction:column;gap:4px}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes glowPulse{0%,to{box-shadow:0 0 10px #0ea5e933}50%{box-shadow:0 0 25px #0ea5e980}}.animate-fadeInUp{animation:fadeInUp .5s ease forwards}.animate-fadeIn{animation:fadeIn .4s ease forwards}.animate-glow{animation:glowPulse 3s ease-in-out infinite}.page-header h1,.dashboard-welcome h1,.auth-header h1{font-family:var(--font-display);letter-spacing:.03em}a:hover{color:var(--accent-light)}.chat-input-form input:focus{border-color:var(--accent);box-shadow:0 0 0 2px #0ea5e91a,var(--shadow-glow-sm)}.chat-input-form button{background:linear-gradient(135deg,var(--accent),var(--accent-hover));box-shadow:0 2px 6px #0ea5e933}.chat-input-form button:hover:not(:disabled){background:linear-gradient(135deg,var(--accent-light),var(--accent));box-shadow:var(--shadow-glow-sm)}
