:root{--primary: #2c78c8;--primary-light: #4191e6;--primary-dark: #205fa6;--primary-glow: rgba(44, 120, 200, .28);--accent-green: #029000;--accent-green-light: #17a317;--accent-orange: #f2b24d;--accent-orange-light: #f7c86d;--accent-red: #ff5a57;--accent-red-light: #ff7b77;--accent-purple: #8b5cf6;--accent-cyan: #06b6d4;--bg-base: #edf2f7;--bg-surface: #243445;--bg-elevated: #2c4052;--bg-card: #ffffff;--bg-card-hover: #f3f7fb;--bg-input: #1f2d3b;--bg-overlay: rgba(0, 0, 0, .65);--text-primary: #112031;--text-secondary: #4b5f75;--text-muted: #6c8094;--text-accent: #4191e6;--border-subtle: rgba(17, 32, 49, .08);--border-light: rgba(17, 32, 49, .14);--border-active: rgba(44, 120, 200, .5);--shadow-sm: 0 2px 6px rgba(15, 23, 42, .08);--shadow-md: 0 8px 24px rgba(15, 23, 42, .12);--shadow-lg: 0 18px 48px rgba(15, 23, 42, .16);--shadow-glow: 0 0 24px rgba(44, 120, 200, .18);--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:linear-gradient(180deg,#eef3f8,#e7edf4);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:#21486f}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);background:#f8fbff}.main-content.no-sidebar{margin-left:0}.main-content.lesson-focus-layout{padding:8px var(--space-lg) var(--space-lg)}.app-header{position:fixed;top:0;left:0;right:0;height:var(--header-height);background:var(--bg-surface);border-bottom:1px solid rgba(255,255,255,.06);display:flex;align-items:center;padding:0 var(--space-lg);z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);background:#243445f5}.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:#f8fafc;white-space:nowrap}.header-logo-text span{color:#21486f}.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:#f8fafc;transition:all var(--transition-fast)}.header-search input::placeholder{color:#6d849a}.header-search input:focus{border-color:var(--border-active);box-shadow:0 0 0 3px var(--primary-glow);background:#93c5fd1f}.header-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:#6d849a;font-size:14px;pointer-events:none}.header-right{display:flex;align-items:center;gap:var(--space-md);margin-left:auto}.header-lesson-actions{display:flex;align-items:center;gap:6px;margin-right:2px}.header-lesson-btn{position:relative;border-radius:var(--radius-full);border:1px solid rgba(191,219,254,.72);background:linear-gradient(180deg,#60a5faf2,#3b82f6eb 48%,#1d4ed8f0);color:#21486f;font-size:.75rem;font-weight:700;line-height:1;padding:8px 12px;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 12px 24px #0f172a47,0 4px #164eaad1,inset 0 1px #ffffff57,inset 0 -1px #1e40af66;text-shadow:0 1px 2px rgba(15,23,42,.28)}.header-lesson-btn:before{content:"";position:absolute;inset:1px 1px auto 1px;height:48%;border-radius:inherit;background:linear-gradient(180deg,#ffffff47,#fff0);pointer-events:none}.header-lesson-btn:hover{transform:translateY(-1px);filter:brightness(1.06)}.header-lesson-edit-btn{width:38px;height:38px;padding:0;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#fbbf24fa,#f59e0bf2,#d97706f5);border-color:#fef08acc;box-shadow:0 12px 24px #78350f38,0 4px #b45309d9,inset 0 1px #ffffff59,inset 0 -1px #92400e59}.header-lesson-next-btn{background:linear-gradient(180deg,#60a5fafa,#3b82f6f2 48%,#1d4ed8f5);border-color:#dbeafed1}.header-lesson-exit-btn{background:linear-gradient(180deg,#e2e8f0fa,#bfdbfeeb 48%,#93c5fdf0);border-color:#eff6ffe6;color:#1e3a5f;text-shadow:none;box-shadow:0 12px 24px #0f172a2e,0 4px #60a5fa99,inset 0 1px #ffffff80,inset 0 -1px #60a5fa3d}.header-status-badge{display:flex;align-items:center;gap:var(--space-sm);padding:6px 14px;background:#94a3b82e;border:1px solid rgba(255,255,255,.12);border-radius:var(--radius-full);font-size:var(--font-sm);color:#d9e3ee;box-shadow:inset 0 0 0 1px #ffffff0a}.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:linear-gradient(180deg,#edf4fb,#e4edf7);border-right:1px solid rgba(148,163,184,.16);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:#6f86a0;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:#35506a;cursor:pointer;transition:all var(--transition-fast);border-left:3px solid transparent;font-size:var(--font-sm)}.sidebar-nav-item:hover{background:#60a5fa24;color:#223d56}.sidebar-nav-item.active{background:linear-gradient(180deg,#60a5fa33,#3b82f61f);color:#1f5e95;border-left-color:var(--primary)}.sidebar-nav-icon{width:34px;height:34px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:linear-gradient(180deg,#ffffffb8,#dbeafe8c);border:1px solid rgba(148,163,184,.16);box-shadow:inset 0 1px #fffc,0 1px 2px #1e293b0d}.sidebar-nav-item:hover .sidebar-nav-icon{background:linear-gradient(180deg,#ffffffd1,#bfdbfe9e);border-color:#60a5fa3d}.sidebar-nav-item.active .sidebar-nav-icon{background:linear-gradient(180deg,#60a5fa42,#3b82f62e);border-color:#3b82f638;box-shadow:inset 0 1px #ffffff73,0 2px 6px #3b82f61f}.sidebar-nav-label{flex:1;min-width:0}.sidebar-nav-badge{font-size:.72rem;min-width:28px;padding:3px 8px;border-radius:999px;background:linear-gradient(180deg,#ffffffc7,#e2e8f0e6);border:1px solid rgba(148,163,184,.18);color:#5f748b;font-weight:700;text-align:center;box-shadow:inset 0 1px #ffffffd1,0 1px 2px #1e293b0a}.sidebar-nav-item.active .sidebar-nav-badge{background:linear-gradient(180deg,#60a5fa38,#3b82f629);border-color:#3b82f63d;color:#1f5e95}.sidebar-progress{padding:var(--space-md) var(--space-lg);border-top:1px solid rgba(148,163,184,.14);margin-top:var(--space-md)}.sidebar-progress-label{font-size:var(--font-xs);color:#6d849a;margin-bottom:var(--space-sm);display:flex;justify-content:space-between}.sidebar-progress-bar{height:4px;background:#94a3b82e;border-radius:var(--radius-full);overflow:hidden}.sidebar-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-light),var(--accent-green));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:#667e96;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);color:#23384e}.page-header p{font-size:var(--font-lg);color:var(--text-secondary)}.welcome-banner{background:linear-gradient(135deg,#2c78c81a,#f2b24d14);border:1px solid rgba(44,120,200,.18);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);box-shadow:var(--shadow-sm)}.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),var(--accent-orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:var(--font-sm);color:#667e96;margin-top:var(--space-xs)}.dashboard-panels{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.dashboard-panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.dashboard-panel-primary{background:linear-gradient(135deg,#2c78c81f,#f2b24d14),var(--bg-card);border-color:#2c78c838}.dashboard-panel-label{font-size:var(--font-xs);text-transform:uppercase;letter-spacing:.08em;font-weight:700;color:var(--primary);margin-bottom:var(--space-sm)}.dashboard-panel h3{font-size:var(--font-2xl);font-weight:800;color:#23384e;margin-bottom:var(--space-sm)}.dashboard-panel p{color:var(--text-secondary);margin-bottom:var(--space-lg);max-width:42ch}.dashboard-panel-btn{min-width:220px}.dashboard-preview-note{margin-bottom:var(--space-xl);padding:14px 18px;border-radius:var(--radius-lg);background:linear-gradient(180deg,#f8fbff,#eef5fd);border:1px solid rgba(96,165,250,.18);color:#4d6379;box-shadow:var(--shadow-sm)}.dashboard-preview-note strong{color:#21486f}.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;box-shadow:var(--shadow-sm)}.module-card:hover{transform:translateY(-4px);border-color:var(--border-active);background:var(--bg-card-hover);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:#667e96;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:#667e96}.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:#dfe7ef;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:#667e96;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);background:#fff;border:1px solid var(--border-subtle);border-radius:var(--radius-xl);padding:var(--space-xl);box-shadow:var(--shadow-sm)}.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(180deg,var(--primary-light),var(--primary));color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:linear-gradient(180deg,#5aa2ee,var(--primary));transform:translateY(-1px);box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-secondary{background:#f8fbff;border:1px solid var(--border-light);color:var(--text-secondary)}.btn-secondary:hover{border-color:var(--border-active);color:var(--text-primary);background:#edf5ff}.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);box-shadow:var(--shadow-sm)}.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:#edf5ff;display:flex;align-items:center;justify-content:center;font-size:var(--font-sm);font-weight:700;color:var(--primary);flex-shrink:0}.lesson-item.completed .lesson-number{background:#10b98126;color:var(--accent-green)}.lesson-item.next-lesson-focus{border-color:#60a5fabf;box-shadow:0 0 0 1px #60a5fa33,0 0 24px #2563eb2e;animation:nextLessonPulse 1.8s ease-in-out 3}.lesson-info{flex:1}.lesson-info h4{font-size:var(--font-base);font-weight:600}.lesson-info p{font-size:var(--font-sm);color:#667e96}.lesson-duration{font-size:var(--font-sm);color:#667e96;flex-shrink:0}.lesson-arrow{color:#667e96;transition:transform var(--transition-fast)}.lesson-item:hover .lesson-arrow{transform:translate(4px);color:#21486f}.lesson-page{width:100%;max-width:none}.lesson-nav{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:2px;flex-wrap:nowrap}.lesson-nav-main{display:flex;align-items:flex-start;justify-content:flex-start;min-width:0;flex:1 1 auto}.lesson-step-header{display:none}.lesson-breadcrumb{display:flex;align-items:center;flex-wrap:wrap;gap:6px;font-size:.6875rem;line-height:1.1;color:#667e96;opacity:.8}.lesson-breadcrumb a{color:#667e96}.lesson-breadcrumb a:hover{color:var(--text-accent)}.lesson-breadcrumb .separator{color:#667e96}.lesson-exit-btn{flex-shrink:0;padding:8px 12px;border-color:var(--border-active);color:var(--text-primary);background:#2563eb14}.lesson-nav-actions{display:none}.lesson-edit-btn{width:34px;height:34px;flex-shrink:0}.lesson-next-btn{flex-shrink:0;padding:8px 12px;font-size:var(--font-xs)}.lesson-exit-btn:hover{background:#2563eb2e;color:var(--text-primary);transform:translateY(-1px)}.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:#667e96}.immersive-lesson .lesson-title-bar{display:none}.immersive-lesson .lesson-nav{margin-bottom:0;min-height:0}.immersive-lesson .lesson-bottom-nav{display:none}#immersive-player-root{display:flex;flex-direction:column;width:100%;height:calc(100vh - 122px);min-height:0;margin-top:0;border-radius:var(--radius-xl);overflow:hidden;box-shadow:0 10px 40px #00000080;background:var(--bg-card);border:1px solid var(--border-light)}.immersive-player-container{display:flex;flex-direction:column;height:100%;position:relative;min-height:0}.immersive-viewport{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#000000e6,#0f1117);overflow:hidden;padding:6px}.immersive-stage{position:relative;display:flex;flex-direction:column;align-items:center;gap:0;width:fit-content;max-width:100%;max-height:100%;flex:0 0 auto}.immersive-image-wrapper{position:relative;display:block;box-shadow:var(--shadow-lg);border-radius:var(--radius-md);overflow:hidden;width:fit-content;max-width:100%;background:#000;line-height:0;flex:0 0 auto}.immersive-image-wrapper img{width:auto;height:auto;max-width:min(100%,2480px);max-height:calc(100vh - 8px);display:block;object-fit:contain}#immersive-player-root.image-size-fit .immersive-image-wrapper img{max-width:min(100%,2480px);max-height:calc(100vh - 8px)}#immersive-player-root.image-size-adaptive .immersive-stage,#immersive-player-root.image-size-large .immersive-stage{width:100%;display:flex;justify-content:center}#immersive-player-root.image-size-large .immersive-image-wrapper{width:min(140vw,3000px);max-width:min(140vw,3000px)}#immersive-player-root.image-size-large .immersive-image-wrapper img{width:100%;max-width:none;max-height:calc(100vh - 8px);height:auto}#immersive-player-root.image-size-zoom .immersive-stage{width:100%}#immersive-player-root.image-size-zoom .immersive-image-wrapper{width:min(110vw,2048px);max-width:min(110vw,2048px)}#immersive-player-root.image-size-zoom .immersive-image-wrapper img{width:100%;max-width:none;max-height:calc(100vh - 8px);height:auto}.immersive-stage-nav{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:13}.subtitle-step-counter{font-size:var(--font-xs);color:#21486f;text-transform:uppercase;letter-spacing:1px;font-weight:700;margin-bottom:1px}.subtitle-text{font-size:var(--font-base);color:var(--text-primary);line-height:1.5;margin:0}.immersive-caption-panel{position:relative;width:min(84%,1120px);padding:10px 18px;border-radius:var(--radius-lg);background:linear-gradient(180deg,#0a0c12e0,#0a0c1294);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.14);box-shadow:var(--shadow-md);text-align:center;z-index:12}.lesson-header-caption{width:min(100%,680px);padding:7px 16px;background:linear-gradient(180deg,#121a27c2,#1c2738a3);border-color:#93c5fd42;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lesson-header-caption .subtitle-step-counter{color:#93c5fd}.lesson-header-caption .subtitle-text{font-size:var(--font-sm);line-height:1.35;color:#e8f0fb}.immersive-photo-caption{position:absolute;left:50%;bottom:16px;transform:translate(-50%);width:min(54%,700px);padding:10px 18px;border-radius:16px;background:linear-gradient(180deg,#60a5faf2,#3b82f6eb 48%,#1d4ed8f0);border:1px solid rgba(191,219,254,.75);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:12;box-shadow:0 16px 34px #0f172a6b,0 5px #164eaad9,inset 0 1px #ffffff59,inset 0 -1px #1e40af73}.immersive-photo-caption:before{content:"";position:absolute;inset:1px 1px auto 1px;height:42%;border-radius:14px 14px 10px 10px;background:linear-gradient(180deg,#ffffff4d,#fff0);pointer-events:none}.immersive-photo-caption .subtitle-text{position:relative;font-size:var(--font-sm);line-height:1.35;font-weight:700;letter-spacing:.01em;color:#21486f;text-shadow:0 1px 2px rgba(15,23,42,.3)}.subtitle-nav-btn{padding:10px 18px;background:#93c5fd1f;border:1px solid var(--border-subtle);color:var(--text-primary);border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:all var(--transition-fast)}.subtitle-nav-btn-side{position:absolute;top:50%;transform:translateY(-50%);pointer-events:auto;background:linear-gradient(180deg,#60a5faf2,#3b82f6eb 48%,#1d4ed8f0);border:1px solid rgba(191,219,254,.75);box-shadow:0 16px 34px #0f172a6b,0 5px #164eaad9,inset 0 1px #ffffff59,inset 0 -1px #1e40af73;color:#21486f;text-shadow:0 1px 2px rgba(15,23,42,.28);z-index:13}.subtitle-nav-btn-side:before{content:"";position:absolute;inset:1px 1px auto 1px;height:48%;border-radius:calc(var(--radius-md) - 1px) calc(var(--radius-md) - 1px) 8px 8px;background:linear-gradient(180deg,#ffffff52,#fff0);pointer-events:none}.subtitle-nav-btn-side>*{position:relative}.subtitle-nav-btn-prev{left:18px}.subtitle-nav-btn-next{right:18px}.subtitle-nav-btn:hover:not(:disabled){background:linear-gradient(180deg,#7db8fffa,#60a5faf2 48%,#2563ebf5);border-color:#dbeafee6;color:#fff}.subtitle-nav-btn:disabled{opacity:.3;cursor:not-allowed}.immersive-edit-btn{width:44px;height:44px;border-radius:50%;background:var(--bg-surface);border:1px solid var(--border-light);color:var(--text-primary);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;transition:all var(--transition-fast)}.immersive-edit-btn:hover{background:#93c5fd1f;transform:scale(1.05)}.immersive-edit-btn.active{background:var(--primary);border-color:#21486f;color:#fff;box-shadow:var(--shadow-glow)}.immersive-no-image{color:#667e96;font-size:var(--font-lg)}.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}}@keyframes nextLessonPulse{0%,to{transform:translateY(0)}50%{transform:translateY(-2px)}}.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:#667e96;text-align:center;border-top:1px solid rgba(148,163,184,.14)}.lesson-bottom-nav{display:grid;grid-template-columns:max-content auto max-content;justify-content:center;align-items:center;gap:var(--space-sm);margin-top:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid rgba(148,163,184,.14)}.lesson-bottom-spacer{min-width:0}.lesson-bottom-slot{display:flex}.lesson-bottom-slot-start{justify-content:flex-end}.lesson-bottom-slot-end{justify-content:flex-start}.lesson-bottom-nav .btn{max-width:100%}.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:#93c5fd1f;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:#667e96}.kb-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:#667e96;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:linear-gradient(180deg,#f8fbff,#eef4fb);border:1px solid rgba(148,163,184,.24);border-radius:var(--radius-full);color:#4a6078;font-size:var(--font-sm);transition:all var(--transition-fast)}.kb-category-btn:hover,.kb-category-btn.active{background:linear-gradient(180deg,#60a5fa,#3b82f6);border-color:#3b82f680;color:#fff;box-shadow:0 6px 16px #3b82f629}.kb-results-count{font-size:var(--font-sm);color:#667e96;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:3px 10px;border-radius:var(--radius-full);background:linear-gradient(180deg,#f8fbff,#eef4fb);border:1px solid rgba(148,163,184,.2);color:#6b8198;font-weight:600;flex-shrink:0}.faq-toggle{margin-left:auto;color:#667e96;transition:transform var(--transition-fast);flex-shrink:0}.faq-item.open .faq-toggle{transform:rotate(180deg);color:#21486f}.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);max-height:360px;object-fit:contain}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:3000;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.lightbox-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#04060ce0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.lightbox-dialog{position:relative;z-index:1;max-width:min(1200px,100%);max-height:min(88vh,100%);padding:var(--space-lg);border-radius:var(--radius-lg);background:#12141eeb;border:1px solid var(--border-light);box-shadow:var(--shadow-lg)}.lightbox-image{max-width:100%;max-height:calc(88vh - 64px);border-radius:var(--radius-md)}.lightbox-close{position:absolute;top:10px;right:10px;width:36px;height:36px;border-radius:var(--radius-full);background:#94a3b82e;color:var(--text-primary);font-size:18px;transition:background var(--transition-fast),transform var(--transition-fast)}.lightbox-close:hover{background:#ffffff29;transform:scale(1.05)}@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}.header-search{display:none}}.no-results{text-align:center;padding:var(--space-3xl);color:#667e96}.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:#667e96;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:#667e96;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:#667e96;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:#667e96;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:#667e96;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:#667e96;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:#667e96}.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:#667e96;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:#667e96;margin-bottom:4px}.admin-store-token{font-family:SF Mono,Cascadia Code,monospace;background:linear-gradient(180deg,#f8fbff,#eef4fb);border:1px solid rgba(148,163,184,.24);color:#4a6078;padding:3px 8px;border-radius:10px;box-shadow:inset 0 1px #fffc,0 1px 2px #0f172a0a}.admin-trial-badge{padding:3px 10px;border-radius:var(--radius-full);background:linear-gradient(180deg,#fff5dd,#ffe9b8);border:1px solid rgba(245,158,11,.22);color:#9a5b00;font-weight:700;box-shadow:inset 0 1px #ffffffbf,0 1px 2px #0f172a0a}.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:#667e96;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:7px 12px;border-radius:12px;font-size:var(--font-xs);font-weight:700;border:1px solid rgba(148,163,184,.24);background:linear-gradient(180deg,#f8fbff,#eef4fb);color:#3f566e;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;box-shadow:inset 0 1px #ffffffd1,0 1px 2px #0f172a0a}.admin-btn-copy:hover{border-color:#60a5fa6b;color:#2b6cb0;background:linear-gradient(180deg,#fff,#f4f8fd)}.admin-btn-toggle.disable{background:linear-gradient(180deg,#f59e0b,#d97706);color:#fff9eb;border-color:#b4530975;text-shadow:0 1px 1px rgba(120,53,15,.25)}.admin-btn-toggle.disable:hover{border-color:#92400e8c;color:#fff;background:linear-gradient(180deg,#f7aa25,#ea860b)}.admin-btn-toggle.enable{background:linear-gradient(180deg,#22c55e,#16a34a);color:#f3fff7;border-color:#15803d61;text-shadow:0 1px 1px rgba(20,83,45,.2)}.admin-btn-toggle.enable:hover{border-color:#15803d80;color:#fff;background:linear-gradient(180deg,#32d26b,#1caf52)}.admin-btn-delete{background:linear-gradient(180deg,#ef4444,#dc2626);color:#fff5f5;border-color:#991b1b6b;text-shadow:0 1px 1px rgba(127,29,29,.22)}.admin-btn-delete:hover{border-color:#7f1d1d8c;color:#fff;background:linear-gradient(180deg,#f05252,#e03131)}.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:#667e96;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:linear-gradient(180deg,#f8fbff,#eef4fb);border:1px solid rgba(148,163,184,.28);border-radius:var(--radius-md);color:#23384e;font-size:var(--font-base);transition:border-color var(--transition-fast),box-shadow var(--transition-fast),background var(--transition-fast);box-shadow:inset 0 1px #fffc,0 1px 2px #0f172a0a}.admin-modal-field input:focus{outline:none;border-color:#3b82f67a;background:linear-gradient(180deg,#fff,#f4f8fd);box-shadow:0 0 0 4px #3b82f61f,0 10px 24px #3b82f614}.admin-modal-field input::placeholder{color:#7b8da3}.admin-modal-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);margin-top:var(--space-lg)}.header-manager-badge,.header-student-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(255,255,255,.16);color:#fff;border-radius:999px;padding:10px 14px;font-size:14px;cursor:pointer;transition:background .2s ease,transform .2s ease}.header-manager-badge:hover,.header-student-badge:hover{transform:translateY(-1px)}.header-manager-badge{background:linear-gradient(180deg,#37526a,#2c4052)}.header-manager-badge:hover{background:linear-gradient(180deg,#41607a,#35506a)}.header-student-badge{background:linear-gradient(180deg,var(--primary-light),var(--primary))}.header-student-badge:hover{background:linear-gradient(180deg,#5aa2ee,var(--primary))}.session-entry-shell{width:min(100%,980px);display:flex;flex-direction:column;gap:18px}.session-brand{display:flex;align-items:center;gap:16px;padding:8px 12px}.session-brand-mark{width:54px;height:54px;border-radius:18px;display:grid;place-items:center;font-size:1.5rem;font-weight:800;color:#21486f;background:linear-gradient(180deg,#5aa2ee,#3b82f6 55%,#1d4ed8);box-shadow:0 14px 28px #0f172a2e,0 4px #1d4ed8ad,inset 0 1px #ffffff59}.session-brand-copy{display:flex;flex-direction:column;gap:4px}.session-brand-title{font-size:clamp(1.5rem,2vw,2rem);font-weight:800;color:#233445;letter-spacing:-.02em}.session-brand-title span{color:#3b82f6}.session-brand-copy p{margin:0;color:#61748a;font-size:.98rem}.session-entry-page,.manager-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:48px 20px;background:radial-gradient(circle at top left,rgba(16,185,129,.14),transparent 28%),radial-gradient(circle at top right,rgba(59,130,246,.14),transparent 24%),linear-gradient(180deg,#f8fafc,#eef3f8)}.manager-page{display:block;min-height:auto;padding-top:32px}.manager-page .admin-header h1{background:none;-webkit-text-fill-color:initial;color:#0f172a}.manager-page .admin-header p{color:#475569}.manager-page .admin-stat-card{background:#1e2235;border-color:#ffffff0f}.manager-page .admin-stat-value{color:#f8fafc}.manager-page .admin-stat-label{color:#94a3b8}.session-entry-card,.manager-auth-card{width:min(860px,100%);background:#fffffff5;border:1px solid rgba(15,23,42,.08);border-radius:28px;box-shadow:0 24px 60px #0f172a24;padding:28px}.session-entry-topbar{display:flex;justify-content:flex-end;gap:14px}.session-manager-link,.session-admin-link{border:none;background:transparent;color:var(--primary);font-weight:700;cursor:pointer}.session-entry-header,.manager-auth-card{text-align:center}.session-entry-icon,.manager-auth-icon{width:72px;height:72px;margin:0 auto 18px;border-radius:22px;display:grid;place-items:center;font-size:34px;background:linear-gradient(135deg,#10b98124,#3b82f624)}.session-entry-header h1,.manager-auth-card h1{margin-bottom:10px}.session-entry-header p,.manager-auth-card p{color:#667e96;max-width:560px;margin:0 auto}.session-entry-form,.manager-pin-form{margin-top:28px}.session-field-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.session-field{display:flex;flex-direction:column;gap:8px;font-weight:600;color:var(--text-primary)}.session-field input,.manager-pin-form input{width:100%;border:1px solid rgba(148,163,184,.28);border-radius:14px;padding:14px 16px;font-size:16px;background:linear-gradient(180deg,#f8fbff,#eef4fb);color:#23384e;box-shadow:inset 0 1px #fffc,0 1px 2px #0f172a0a}.session-field input::placeholder,.manager-pin-form input::placeholder{color:#7b8da3}.session-field input:focus,.manager-pin-form input:focus{outline:none;border-color:#3b82f67a;background:linear-gradient(180deg,#fff,#f4f8fd);box-shadow:0 0 0 4px #3b82f61f,0 10px 24px #3b82f614}.session-start-btn,.manager-pin-actions .btn{margin-top:18px}.session-student-list{margin-top:28px;border-top:1px solid rgba(15,23,42,.08);padding-top:24px}.session-student-list-title{font-weight:700;margin-bottom:14px}.session-student-grid,.manager-student-list{display:grid;gap:14px}.session-student-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.session-student-card,.manager-student-card{border:1px solid rgba(15,23,42,.1);background:#fff;border-radius:18px;padding:16px;text-align:left;box-shadow:0 10px 24px #0f172a0f}.session-student-card{cursor:pointer;display:flex;flex-direction:column;gap:6px}.session-student-card span,.session-student-card small,.manager-student-meta{color:#667e96}.manager-header-actions,.manager-pin-actions,.manager-student-actions{display:flex;gap:12px;flex-wrap:wrap}.manager-student-main{display:flex;align-items:center;justify-content:space-between;gap:16px}.manager-student-main h3{margin-bottom:4px;color:#0f172a}.manager-student-main p{color:#475569}.manager-student-progress{font-size:28px;font-weight:800;color:var(--primary)}.manager-student-meta{display:flex;gap:18px;flex-wrap:wrap;margin:10px 0 14px;font-size:14px;color:#64748b}.manager-student-actions .btn{border-color:#0f172a1f}.manager-student-actions .btn.btn-secondary{background:#f8fafc;color:#0f172a}.manager-student-actions .btn.btn-secondary:hover{background:#eef2ff}.manager-student-bar{width:100%;height:10px;border-radius:999px;background:#94a3b82e;overflow:hidden;margin-bottom:14px}.manager-student-bar-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#10b981,#22c55e)}@media (max-width: 900px){.session-field-grid{grid-template-columns:1fr}.session-entry-shell{gap:14px}.session-brand{padding:0 4px;align-items:flex-start}.session-brand-mark{width:46px;height:46px;border-radius:14px;font-size:1.25rem}.session-brand-title{font-size:1.35rem}.session-brand-copy p{font-size:.9rem}.header-manager-badge,.header-student-badge{padding:8px 12px;font-size:13px}}#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)}.lightbox-overlay{padding:var(--space-md)}.lightbox-dialog{width:100%;padding:var(--space-md)}.lesson-nav{align-items:flex-start}.lesson-nav-actions{width:100%;justify-content:flex-start}#immersive-player-root{height:auto;margin-top:var(--space-md)}.immersive-viewport{padding:4px}.immersive-image-wrapper img,#immersive-player-root.image-size-fit .immersive-image-wrapper img,#immersive-player-root.image-size-large .immersive-image-wrapper img,#immersive-player-root.image-size-zoom .immersive-image-wrapper img{max-height:84vh}.subtitle-nav-btn-side{top:auto;bottom:14px;transform:none}.immersive-caption-panel{width:calc(100% - 24px);padding:12px 14px}}
