:root{--primary: #2563eb;--primary-light: #3b82f6;--primary-dark: #1d4ed8;--primary-glow: rgba(37, 99, 235, .25);--accent-green: #10b981;--accent-green-light: #34d399;--accent-orange: #f59e0b;--accent-orange-light: #fbbf24;--accent-red: #ef4444;--accent-red-light: #f87171;--accent-purple: #8b5cf6;--accent-cyan: #06b6d4;--bg-base: #0f1117;--bg-surface: #161822;--bg-elevated: #1e2030;--bg-card: #1a1c2e;--bg-card-hover: #222440;--bg-input: #12141e;--bg-overlay: rgba(0, 0, 0, .65);--text-primary: #f1f3f9;--text-secondary: #a0a6be;--text-muted: #6b7194;--text-accent: #60a5fa;--border-subtle: rgba(255, 255, 255, .06);--border-light: rgba(255, 255, 255, .1);--border-active: rgba(37, 99, 235, .5);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 24px rgba(37, 99, 235, .15);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .4s cubic-bezier(.4, 0, .2, 1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--font-5xl: 3rem;--sidebar-width: 280px;--header-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background:var(--bg-base);color:var(--text-primary);line-height:1.6;min-height:100vh;overflow-x:hidden}a{color:var(--text-accent);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-light)}img{max-width:100%;height:auto;display:block}button{font-family:var(--font-family);cursor:pointer;border:none;outline:none;font-size:var(--font-sm)}input,select,textarea{font-family:var(--font-family);font-size:var(--font-base)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}#app{min-height:100vh;display:flex;flex-direction:column}.app-layout{display:flex;min-height:calc(100vh - var(--header-height));margin-top:var(--header-height)}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-xl);min-height:calc(100vh - var(--header-height));transition:margin-left var(--transition-base)}.main-content.no-sidebar{margin-left:0}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 var(--space-lg);z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#161822d9}.header-logo{display:flex;align-items:center;gap:var(--space-md);cursor:pointer;flex-shrink:0}.header-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--primary),var(--accent-cyan));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#fff;box-shadow:var(--shadow-glow)}.header-logo-text{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);white-space:nowrap}.header-logo-text span{color:var(--primary-light)}.header-search{flex:1;max-width:480px;margin:0 var(--space-xl);position:relative}.header-search input{width:100%;height:40px;background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-full);padding:0 var(--space-md) 0 42px;color:var(--text-primary);transition:all var(--transition-fast)}.header-search input::placeholder{color:var(--text-muted)}.header-search input:focus{border-color:var(--border-active);box-shadow:0 0 0 3px var(--primary-glow);background:var(--bg-elevated)}.header-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:14px;pointer-events:none}.header-right{display:flex;align-items:center;gap:var(--space-md);margin-left:auto}.header-status-badge{display:flex;align-items:center;gap:var(--space-sm);padding:6px 14px;background:var(--bg-elevated);border:1px solid var(--border-light);border-radius:var(--radius-full);font-size:var(--font-sm);color:var(--text-secondary)}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-green);animation:statusPulse 2s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.4}}.header-admin-badge{display:flex;align-items:center;gap:var(--space-xs);padding:6px 14px;background:linear-gradient(135deg,#f59e0b26,#ef44441a);border:1px solid rgba(245,158,11,.3);border-radius:var(--radius-full);font-size:var(--font-sm);font-weight:600;color:var(--accent-orange-light);cursor:pointer;transition:all var(--transition-fast)}.header-admin-badge:hover{border-color:var(--accent-orange);background:#f59e0b33}.app-sidebar{position:fixed;top:var(--header-height);left:0;bottom:0;width:var(--sidebar-width);background:var(--bg-surface);border-right:1px solid var(--border-subtle);overflow-y:auto;z-index:50;padding:var(--space-lg) 0;transition:transform var(--transition-base)}.sidebar-section{margin-bottom:var(--space-lg)}.sidebar-section-title{font-size:var(--font-xs);font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;padding:0 var(--space-lg);margin-bottom:var(--space-sm)}.sidebar-nav-item{display:flex;align-items:center;gap:var(--space-md);padding:10px var(--space-lg);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent;font-size:var(--font-sm)}.sidebar-nav-item:hover{background:var(--bg-elevated);color:var(--text-primary)}.sidebar-nav-item.active{background:#2563eb14;color:var(--primary-light);border-left-color:var(--primary)}.sidebar-nav-icon{width:32px;height:32px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:var(--bg-elevated)}.sidebar-nav-item.active .sidebar-nav-icon{background:var(--primary-glow)}.sidebar-nav-label{flex:1;min-width:0}.sidebar-nav-badge{font-size:var(--font-xs);padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-muted)}.sidebar-nav-item.active .sidebar-nav-badge{background:var(--primary-glow);color:var(--primary-light)}.sidebar-progress{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border-subtle);margin-top:var(--space-md)}.sidebar-progress-label{font-size:var(--font-xs);color:var(--text-muted);margin-bottom:var(--space-sm);display:flex;justify-content:space-between}.sidebar-progress-bar{height:4px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.sidebar-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--accent-cyan));border-radius:var(--radius-full);transition:width var(--transition-slow)}.access-denied-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-base);padding:var(--space-xl)}.access-denied-container{width:100%;max-width:480px;text-align:center}.access-denied-icon{width:100px;height:100px;background:linear-gradient(135deg,#ef444426,#f59e0b1a);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:48px;margin:0 auto var(--space-xl);border:1px solid rgba(239,68,68,.2);animation:lockPulse 3s ease-in-out infinite}@keyframes lockPulse{0%,to{border-color:#ef444433;box-shadow:0 0 #ef444400}50%{border-color:#ef444466;box-shadow:0 0 32px #ef44441a}}.access-denied-title{font-size:var(--font-3xl);font-weight:800;margin-bottom:var(--space-md);background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.access-denied-text{color:var(--text-secondary);font-size:var(--font-lg);margin-bottom:var(--space-sm)}.access-denied-subtext{color:var(--text-muted);font-size:var(--font-sm)}.home-page{max-width:1100px}.page-header{margin-bottom:var(--space-2xl)}.page-header h1{font-size:var(--font-3xl);font-weight:800;margin-bottom:var(--space-sm)}.page-header p{font-size:var(--font-lg);color:var(--text-secondary)}.welcome-banner{background:linear-gradient(135deg,#2563eb1f,#06b6d414);border:1px solid var(--border-active);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-2xl);margin-bottom:var(--space-2xl);display:flex;align-items:center;gap:var(--space-xl)}.welcome-banner-icon{font-size:48px;flex-shrink:0}.welcome-banner h2{font-size:var(--font-2xl);font-weight:700;margin-bottom:var(--space-xs)}.welcome-banner p{color:var(--text-secondary)}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-md);margin-bottom:var(--space-2xl)}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center;transition:all var(--transition-base)}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-light);box-shadow:var(--shadow-md)}.stat-value{font-size:var(--font-3xl);font-weight:800;background:linear-gradient(135deg,var(--primary-light),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:var(--font-sm);color:var(--text-muted);margin-top:var(--space-xs)}.modules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.module-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);overflow:hidden;cursor:pointer;transition:all var(--transition-base);position:relative}.module-card:hover{transform:translateY(-4px);border-color:var(--border-active);box-shadow:var(--shadow-lg),var(--shadow-glow)}.module-card-header{padding:var(--space-lg) var(--space-lg) 0;display:flex;align-items:flex-start;gap:var(--space-md)}.module-card-icon{width:48px;height:48px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.module-card-header h3{font-size:var(--font-lg);font-weight:700}.module-card-header p{font-size:var(--font-sm);color:var(--text-muted);margin-top:2px}.module-card-body{padding:var(--space-md) var(--space-lg)}.module-card-meta{display:flex;gap:var(--space-lg);font-size:var(--font-sm);color:var(--text-muted)}.module-card-meta span{display:flex;align-items:center;gap:4px}.module-card-footer{padding:var(--space-md) var(--space-lg) var(--space-lg)}.module-card-progress{height:4px;background:var(--bg-input);border-radius:var(--radius-full);overflow:hidden}.module-card-progress-fill{height:100%;border-radius:var(--radius-full);transition:width var(--transition-slow)}.module-card-progress-label{font-size:var(--font-xs);color:var(--text-muted);margin-top:var(--space-xs);text-align:right}.module-card.locked{opacity:.5;pointer-events:none}.module-card.locked:after{content:"🔒";position:absolute;top:var(--space-md);right:var(--space-md);font-size:20px}.module-page{max-width:1000px}.module-header{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-2xl);padding-bottom:var(--space-xl);border-bottom:1px solid var(--border-subtle)}.module-header-icon{width:64px;height:64px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:28px}.module-header-info h1{font-size:var(--font-3xl);font-weight:800}.module-header-info p{color:var(--text-secondary);margin-top:var(--space-xs)}.module-actions{margin-left:auto;display:flex;gap:var(--space-md)}.btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:10px 20px;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-light),var(--primary));transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-secondary{background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-secondary)}.btn-secondary:hover{border-color:var(--border-active);color:var(--text-primary)}.lessons-list{display:flex;flex-direction:column;gap:var(--space-sm)}.lesson-item{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.lesson-item:hover{border-color:var(--border-active);background:var(--bg-card-hover);transform:translate(4px)}.lesson-item.completed{border-left:3px solid var(--accent-green)}.lesson-number{width:32px;height:32px;border-radius:50%;background:var(--bg-elevated);display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:700;color:var(--text-muted);flex-shrink:0}.lesson-item.completed .lesson-number{background:#10b98126;color:var(--accent-green)}.lesson-info{flex:1}.lesson-info h4{font-size:var(--font-base);font-weight:600}.lesson-info p{font-size:var(--font-sm);color:var(--text-muted)}.lesson-duration{font-size:var(--font-sm);color:var(--text-muted);flex-shrink:0}.lesson-arrow{color:var(--text-muted);transition:transform var(--transition-fast)}.lesson-item:hover .lesson-arrow{transform:translate(4px);color:var(--primary-light)}.lesson-page{max-width:1200px}.lesson-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.lesson-breadcrumb{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-sm);color:var(--text-muted)}.lesson-breadcrumb a{color:var(--text-muted)}.lesson-breadcrumb a:hover{color:var(--text-accent)}.lesson-breadcrumb .separator{color:var(--text-muted)}.lesson-title-bar{margin-bottom:var(--space-xl)}.lesson-title-bar h1{font-size:var(--font-2xl);font-weight:800;margin-bottom:var(--space-xs)}.lesson-title-bar .lesson-meta{display:flex;gap:var(--space-lg);font-size:var(--font-sm);color:var(--text-muted)}.lesson-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-xl);align-items:start}.lesson-instructions{position:sticky;top:calc(var(--header-height) + var(--space-xl))}.lesson-steps{display:flex;flex-direction:column;gap:var(--space-md)}.lesson-step{display:flex;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--transition-fast);cursor:pointer}.lesson-step:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.lesson-step.active{border-color:var(--primary);background:var(--primary-glow)}.lesson-step.active .lesson-step-number{background:var(--primary);color:#fff;box-shadow:0 0 10px var(--primary-glow)}.lesson-step-number{width:28px;height:28px;border-radius:50%;background:var(--primary-glow);color:var(--primary-light);display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:700;flex-shrink:0}.lesson-step-text{font-size:var(--font-sm);line-height:1.7;color:var(--text-secondary)}.lesson-step-text strong{color:var(--text-primary)}.lesson-screenshot-area{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);overflow:hidden;position:relative}.screenshot-highlight{position:absolute;border:3px solid var(--accent-orange);background:#f59e0b26;border-radius:var(--radius-sm);box-shadow:0 0 0 1px #ffffff80,0 0 20px #f59e0b99;pointer-events:none;animation:pulseHighlight 1.5s infinite;z-index:10;transition:all .3s ease}@keyframes pulseHighlight{0%{box-shadow:0 0 0 1px #ffffff80,0 0 #f59e0b66}70%{box-shadow:0 0 0 1px #ffffff80,0 0 0 10px #f59e0b00}to{box-shadow:0 0 0 1px #ffffff80,0 0 #f59e0b00}}.screenshot-highlight.edit-mode{cursor:move;pointer-events:auto;background:#f59e0b59}.resize-handle{display:none;position:absolute;width:14px;height:14px;background:#fff;border:2px solid var(--accent-orange);border-radius:50%;z-index:20}.screenshot-highlight.edit-mode .resize-handle{display:block}.resize-nw{top:-7px;left:-7px;cursor:nwse-resize}.resize-ne{top:-7px;right:-7px;cursor:nesw-resize}.resize-sw{bottom:-7px;left:-7px;cursor:nesw-resize}.resize-se{bottom:-7px;right:-7px;cursor:nwse-resize}.lesson-screenshot-area img{width:100%;cursor:zoom-in;transition:transform var(--transition-base)}.lesson-screenshot-area img:hover{transform:scale(1.02)}.lesson-screenshot-caption{padding:var(--space-md);font-size:var(--font-sm);color:var(--text-muted);text-align:center;border-top:1px solid var(--border-subtle)}.lesson-bottom-nav{display:flex;justify-content:space-between;align-items:center;margin-top:var(--space-2xl);padding-top:var(--space-xl);border-top:1px solid var(--border-subtle)}.btn-complete{background:linear-gradient(135deg,var(--accent-green),var(--accent-green-light));color:#fff;padding:12px 24px;border-radius:var(--radius-md);font-weight:600;transition:all var(--transition-fast)}.btn-complete:hover{transform:translateY(-2px);box-shadow:0 4px 16px #10b9814d}.btn-complete.completed{background:var(--bg-elevated);border:1px solid var(--accent-green);color:var(--accent-green)}.kb-page{max-width:900px}.kb-search{position:relative;margin-bottom:var(--space-2xl)}.kb-search input{width:100%;height:56px;background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:0 var(--space-lg) 0 52px;color:var(--text-primary);font-size:var(--font-lg);transition:all var(--transition-fast)}.kb-search input:focus{border-color:var(--border-active);box-shadow:0 0 0 4px var(--primary-glow)}.kb-search input::placeholder{color:var(--text-muted)}.kb-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:18px}.kb-categories{display:flex;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-xl)}.kb-category-btn{padding:6px 16px;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-full);color:var(--text-secondary);font-size:var(--font-sm);transition:all var(--transition-fast)}.kb-category-btn:hover,.kb-category-btn.active{background:var(--primary-glow);border-color:var(--border-active);color:var(--primary-light)}.kb-results-count{font-size:var(--font-sm);color:var(--text-muted);margin-bottom:var(--space-md)}.faq-list{display:flex;flex-direction:column;gap:var(--space-sm)}.faq-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);overflow:hidden;transition:all var(--transition-fast)}.faq-item:hover{border-color:var(--border-light)}.faq-item.open{border-color:var(--border-active)}.faq-question{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);cursor:pointer;-webkit-user-select:none;user-select:none;width:100%;background:none;color:var(--text-primary);text-align:left;font-size:var(--font-base);font-weight:500}.faq-question:hover{background:var(--bg-card-hover)}.faq-category-tag{font-size:var(--font-xs);padding:2px 8px;border-radius:var(--radius-full);background:var(--bg-elevated);color:var(--text-muted);flex-shrink:0}.faq-toggle{margin-left:auto;color:var(--text-muted);transition:transform var(--transition-fast);flex-shrink:0}.faq-item.open .faq-toggle{transform:rotate(180deg);color:var(--primary-light)}.faq-answer{padding:0 var(--space-lg) var(--space-lg);display:none}.faq-item.open .faq-answer{display:block}.faq-answer p{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.8;margin-bottom:var(--space-md)}.faq-answer p:last-child{margin-bottom:0}.faq-answer img{border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin-top:var(--space-sm)}.slideshow-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-base);z-index:1000;display:flex;flex-direction:column}.slideshow-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:var(--bg-surface);border-bottom:1px solid var(--border-subtle)}.slideshow-header h2{font-size:var(--font-lg);font-weight:600}.slideshow-counter{font-size:var(--font-sm);color:var(--text-muted)}.slideshow-close{width:36px;height:36px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;font-size:18px;transition:all var(--transition-fast)}.slideshow-close:hover{background:var(--accent-red);color:#fff;border-color:var(--accent-red)}.slideshow-body{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-2xl);gap:var(--space-2xl);overflow:hidden}.slideshow-content{display:flex;align-items:center;gap:var(--space-xl);max-width:1600px;width:100%}.slideshow-text{flex:1;max-width:300px}.slideshow-text h3{font-size:var(--font-lg);font-weight:700;margin-bottom:var(--space-md)}.slideshow-text p{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.6}.slideshow-image{flex:3;border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle);box-shadow:var(--shadow-lg)}.slideshow-image img{width:100%}.slideshow-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-lg) var(--space-xl);background:var(--bg-surface);border-top:1px solid var(--border-subtle)}.slideshow-dots{display:flex;gap:var(--space-sm)}.slideshow-dot{width:8px;height:8px;border-radius:50%;background:var(--text-muted);border:none;cursor:pointer;transition:all var(--transition-fast);padding:0}.slideshow-dot.active{background:var(--primary);width:24px;border-radius:var(--radius-full)}.slideshow-nav-btn{width:44px;height:44px;border-radius:50%;background:var(--bg-elevated);border:1px solid var(--border-light);color:var(--text-primary);font-size:18px;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.slideshow-nav-btn:hover{background:var(--primary);border-color:var(--primary);box-shadow:var(--shadow-glow)}.slideshow-nav-btn:disabled{opacity:.3;pointer-events:none}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:transparent;z-index:2000;display:flex;align-items:center;justify-content:center;pointer-events:none;padding:var(--space-xl)}.lightbox-container{position:relative;display:inline-block;pointer-events:auto;border-radius:var(--radius-md);box-shadow:0 24px 64px #000c;border:1px solid var(--border-light);background:var(--bg-card)}.lightbox-container img{display:block;max-width:75vw;max-height:80vh;border-radius:calc(var(--radius-md) - 1px)}.lightbox-controls{position:absolute;top:32px;right:50%;transform:translate(50%);width:100%;max-width:75vw;display:flex;justify-content:flex-end;align-items:center;gap:16px;pointer-events:none;z-index:2001}.lightbox-close-btn{width:44px;height:44px;border-radius:50%;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-light);font-size:20px;cursor:pointer;pointer-events:auto;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.lightbox-close-btn:hover{background:var(--bg-elevated);border-color:var(--border-active);transform:scale(1.05)}.lightbox-edit-btn{width:44px;height:44px;border-radius:50%;background:var(--bg-surface);color:var(--text-primary);border:1px solid var(--border-light);font-size:18px;cursor:pointer;pointer-events:auto;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast)}.lightbox-edit-btn:hover{background:var(--bg-elevated);border-color:var(--border-active);transform:scale(1.05)}.lightbox-edit-btn.active{background:var(--primary);border-color:var(--primary-light);color:#fff;box-shadow:var(--shadow-glow)}.search-results-page{max-width:900px}.search-results-page h1{font-size:var(--font-2xl);margin-bottom:var(--space-lg)}.search-result-item{padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);margin-bottom:var(--space-sm);cursor:pointer;transition:all var(--transition-fast)}.search-result-item:hover{border-color:var(--border-active);transform:translate(4px)}.search-result-type{font-size:var(--font-xs);color:var(--primary-light);text-transform:uppercase;font-weight:600;letter-spacing:.05em;margin-bottom:2px}.search-result-title{font-size:var(--font-base);font-weight:600;margin-bottom:2px}.search-result-excerpt{font-size:var(--font-sm);color:var(--text-muted)}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}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)}}.animate-in{animation:fadeIn .4s ease both}.animate-in-delay-1{animation-delay:.05s}.animate-in-delay-2{animation-delay:.1s}.animate-in-delay-3{animation-delay:.15s}.animate-in-delay-4{animation-delay:.2s}.animate-in-delay-5{animation-delay:.25s}.animate-in-delay-6{animation-delay:.3s}@media (max-width: 1024px){.lesson-content{grid-template-columns:1fr}.lesson-instructions{position:static}}@media (max-width: 768px){:root{--sidebar-width: 0px}.app-sidebar{transform:translate(-100%)}.app-sidebar.open{transform:translate(0);width:280px}.main-content{margin-left:0;padding:var(--space-md)}.modules-grid{grid-template-columns:1fr}.welcome-banner,.module-header{flex-direction:column;text-align:center}.module-actions{margin-left:0}.slideshow-content{flex-direction:column}.slideshow-text{max-width:none;text-align:center}.header-search{display:none}}.no-results{text-align:center;padding:var(--space-3xl);color:var(--text-muted)}.no-results-icon{font-size:48px;margin-bottom:var(--space-md)}.no-results h3{margin-bottom:var(--space-sm);color:var(--text-secondary)}.settings-page{max-width:800px}.settings-override-banner,.settings-default-banner{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);margin-bottom:var(--space-xl);font-size:var(--font-sm)}.settings-override-banner{background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);color:var(--accent-orange-light)}.settings-override-banner .btn{margin-left:auto;flex-shrink:0}.settings-default-banner{background:#10b98114;border:1px solid rgba(16,185,129,.2);color:var(--accent-green-light)}.settings-module-list{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-xl)}.settings-module-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:all var(--transition-fast)}.settings-module-row:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.settings-module-row.disabled{opacity:.55}.settings-module-info{display:flex;align-items:center;gap:var(--space-md)}.settings-module-info strong{display:block;font-size:var(--font-base);font-weight:600}.settings-module-info small{display:block;font-size:var(--font-xs);color:var(--text-muted);margin-top:2px}.settings-module-toggle{display:flex;align-items:center;gap:var(--space-md)}.settings-module-status{font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);min-width:48px;text-align:right}.settings-mod-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}.settings-toggle{position:relative;display:inline-block;width:44px;height:24px;cursor:pointer;flex-shrink:0}.settings-toggle input{opacity:0;width:0;height:0}.settings-toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-full);transition:all var(--transition-fast)}.settings-toggle-slider:before{content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:var(--text-muted);top:2px;left:2px;transition:all var(--transition-fast)}.settings-toggle input:checked+.settings-toggle-slider{background:var(--accent-green);border-color:var(--accent-green)}.settings-toggle input:checked+.settings-toggle-slider:before{transform:translate(20px);background:#fff}.settings-toggle:hover .settings-toggle-slider{border-color:var(--border-active)}.settings-info-card{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg)}.settings-info-icon{font-size:24px;flex-shrink:0;margin-top:2px}.settings-info-card strong{display:block;font-size:var(--font-sm);font-weight:600;margin-bottom:var(--space-xs)}.settings-info-card p{font-size:var(--font-sm);color:var(--text-muted);line-height:1.6}.loading-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-base)}.loading-container{text-align:center}.loading-logo{width:64px;height:64px;background:linear-gradient(135deg,var(--primary),var(--accent-cyan));border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;margin:0 auto var(--space-lg);box-shadow:var(--shadow-glow)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-light);border-top-color:var(--primary);border-radius:50%;margin:0 auto var(--space-md);animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-text{color:var(--text-muted);font-size:var(--font-sm)}.admin-page{max-width:900px}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-xl)}.admin-header h1{font-size:var(--font-2xl);font-weight:800;background:linear-gradient(135deg,var(--text-primary),var(--accent-orange-light));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.admin-header p{color:var(--text-muted);font-size:var(--font-sm);margin-top:4px}.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md);margin-bottom:var(--space-xl)}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:var(--space-lg);text-align:center}.admin-stat-value{font-size:var(--font-2xl);font-weight:800;color:var(--text-primary)}.admin-stat-label{font-size:var(--font-xs);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:4px}.admin-stores-list{display:flex;flex-direction:column;gap:var(--space-md)}.admin-loading{text-align:center;padding:var(--space-2xl);color:var(--text-muted)}.admin-loading p{margin-top:var(--space-md)}.admin-empty{text-align:center;padding:var(--space-2xl);background:var(--bg-card);border:1px dashed var(--border-light);border-radius:var(--radius-lg)}.admin-empty-icon{font-size:48px;margin-bottom:var(--space-md)}.admin-empty h3{font-size:var(--font-lg);font-weight:600;margin-bottom:var(--space-sm)}.admin-empty p{color:var(--text-muted);font-size:var(--font-sm)}.admin-error{text-align:center;padding:var(--space-xl);color:var(--accent-red-light);background:#ef444414;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-lg)}.admin-store-card{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-fast);gap:var(--space-lg)}.admin-store-card:hover{border-color:var(--border-light);background:var(--bg-card-hover)}.admin-store-card.inactive{opacity:.6}.admin-store-info{display:flex;align-items:flex-start;gap:var(--space-md);flex:1;min-width:0}.admin-store-status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;margin-top:6px}.admin-store-status-dot.active{background:var(--accent-green);box-shadow:0 0 8px #10b98166}.admin-store-status-dot.inactive{background:var(--accent-red);box-shadow:0 0 8px #ef44444d}.admin-store-details{min-width:0}.admin-store-details strong{display:block;font-size:var(--font-base);font-weight:700;margin-bottom:4px}.admin-store-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-md);font-size:var(--font-xs);color:var(--text-muted);margin-bottom:4px}.admin-store-token{font-family:SF Mono,Cascadia Code,monospace;background:var(--bg-elevated);padding:1px 6px;border-radius:var(--radius-sm)}.admin-trial-badge{padding:1px 8px;border-radius:var(--radius-full);background:#f59e0b26;color:var(--accent-orange-light);font-weight:600}.admin-paid-badge{padding:1px 8px;border-radius:var(--radius-full);background:#10b98126;color:var(--accent-green-light);font-weight:600}.admin-inactive-badge{padding:1px 8px;border-radius:var(--radius-full);background:#ef444426;color:var(--accent-red-light);font-weight:600}.admin-store-notes{font-size:var(--font-xs);color:var(--text-muted);font-style:italic}.admin-store-actions{display:flex;align-items:center;gap:var(--space-sm);flex-shrink:0}.admin-btn-copy,.admin-btn-toggle,.admin-btn-delete{padding:6px 12px;border-radius:var(--radius-md);font-size:var(--font-xs);font-weight:600;border:1px solid var(--border-light);background:var(--bg-elevated);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.admin-btn-copy:hover{border-color:var(--primary);color:var(--primary-light);background:#2563eb1a}.admin-btn-toggle.disable:hover{border-color:var(--accent-orange);color:var(--accent-orange-light);background:#f59e0b1a}.admin-btn-toggle.enable:hover{border-color:var(--accent-green);color:var(--accent-green-light);background:#10b9811a}.admin-btn-delete:hover{border-color:var(--accent-red);color:var(--accent-red-light);background:#ef44441a}.admin-btn-copy:disabled,.admin-btn-toggle:disabled,.admin-btn-delete:disabled{opacity:.5;cursor:not-allowed}.admin-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-xl)}.admin-modal{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);padding:var(--space-xl);width:100%;max-width:480px;box-shadow:var(--shadow-xl);animation:modalIn .2s ease-out}@keyframes modalIn{0%{opacity:0;transform:scale(.95) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.admin-modal h3{font-size:var(--font-xl);font-weight:700;margin-bottom:var(--space-xs)}.admin-modal-desc{color:var(--text-muted);font-size:var(--font-sm);margin-bottom:var(--space-lg)}.admin-modal-field{margin-bottom:var(--space-md)}.admin-modal-field label{display:block;font-size:var(--font-sm);font-weight:600;margin-bottom:var(--space-xs);color:var(--text-secondary)}.admin-modal-field input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-base);transition:border-color var(--transition-fast)}.admin-modal-field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2563eb26}.admin-modal-field input::placeholder{color:var(--text-muted)}.admin-modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}#toast-container{position:fixed;bottom:var(--space-xl);right:var(--space-xl);z-index:2000;display:flex;flex-direction:column;gap:var(--space-sm);pointer-events:none}.toast{padding:12px 20px;border-radius:var(--radius-lg);font-size:var(--font-sm);font-weight:600;color:#fff;transform:translate(100%);opacity:0;transition:all .3s ease;pointer-events:auto;box-shadow:var(--shadow-lg)}.toast.show{transform:translate(0);opacity:1}.toast-success{background:linear-gradient(135deg,#10b981,#059669)}.toast-error{background:linear-gradient(135deg,#ef4444,#dc2626)}@media (max-width: 768px){.admin-stats{grid-template-columns:repeat(2,1fr)}.admin-store-card{flex-direction:column;align-items:stretch}.admin-store-actions{justify-content:flex-end;margin-top:var(--space-sm)}}
