:root{--color-bg-primary: #0a0a0f;--color-bg-secondary: #12121a;--color-bg-tertiary: #1a1a25;--color-bg-card: rgba(26, 26, 37, .8);--color-bg-glass: rgba(255, 255, 255, .03);--color-primary: #6366f1;--color-primary-light: #818cf8;--color-primary-dark: #4f46e5;--color-secondary: #8b5cf6;--color-accent: #22d3ee;--color-success: #10b981;--color-success-bg: rgba(16, 185, 129, .1);--color-error: #ef4444;--color-error-bg: rgba(239, 68, 68, .1);--color-warning: #f59e0b;--color-warning-bg: rgba(245, 158, 11, .1);--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .1);--color-text-primary: #f8fafc;--color-text-secondary: #94a3b8;--color-text-muted: #64748b;--color-text-inverse: #0a0a0f;--color-border: rgba(255, 255, 255, .08);--color-border-light: rgba(255, 255, 255, .12);--font-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(99, 102, 241, .3);--ease-out-expo: cubic-bezier(.16, 1, .3, 1);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--transition-fast: .15s var(--ease-out-quart);--transition-base: .3s var(--ease-out-expo);--transition-slow: .5s var(--ease-out-expo);--z-dropdown: 100;--z-modal: 200;--z-tooltip: 300;--z-toast: 400}[data-theme=light]{--color-bg-primary: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f1f5f9;--color-bg-card: rgba(255, 255, 255, .9);--color-bg-glass: rgba(0, 0, 0, .03);--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-muted: #94a3b8;--color-text-inverse: #f8fafc;--color-border: rgba(0, 0, 0, .08);--color-border-light: rgba(0, 0, 0, .12);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(99, 102, 241, .2)}[data-theme=light] body:before{background:radial-gradient(ellipse at 20% 20%,rgba(99,102,241,.05) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(139,92,246,.05) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(34,211,238,.02) 0%,transparent 70%)}[data-theme=light] .nav{background:#f8fafce6}[data-theme=light] .mobile-nav{background:#f8fafcf2}[data-theme=light] code{background:#e2e8f0;color:#7c3aed}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--color-bg-card);color:var(--color-primary);border-color:var(--color-primary)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:1.6;color:var(--color-text-primary);background:var(--color-bg-primary);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:radial-gradient(ellipse at 20% 20%,rgba(99,102,241,.08) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(139,92,246,.08) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(34,211,238,.03) 0%,transparent 70%);pointer-events:none;z-index:-1}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:var(--font-semibold);line-height:1.3;color:var(--color-text-primary)}h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}@media (min-width: 768px){h1{font-size:var(--text-4xl)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}}p{margin-bottom:var(--space-4);color:var(--color-text-secondary)}a{color:var(--color-primary-light);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary)}code{font-family:var(--font-mono);font-size:.9em;background:var(--color-bg-tertiary);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);color:var(--color-accent)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);min-height:44px;white-space:nowrap}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;box-shadow:var(--shadow-md),var(--shadow-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg),0 0 30px #6366f166}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--color-bg-tertiary);color:var(--color-text-primary);border:1px solid var(--color-border-light)}.btn-secondary:hover{background:var(--color-bg-card);border-color:var(--color-primary)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-bg-glass);color:var(--color-text-primary)}.btn-success{background:var(--color-success);color:#fff}.btn-error{background:var(--color-error);color:#fff}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all var(--transition-base)}.card:hover{border-color:var(--color-border-light);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-glass{background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-5);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.input{width:100%;padding:var(--space-3) var(--space-4);font-family:var(--font-sans);font-size:var(--text-base);color:var(--color-text-primary);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);transition:all var(--transition-fast);min-height:44px}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f133}.input::placeholder{color:var(--color-text-muted)}.form-label{display:block;margin-bottom:var(--space-2);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.form-input,.form-select{width:100%;padding:var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--text-base);transition:border-color var(--transition-fast)}.form-input:focus,.form-select:focus{outline:none;border-color:var(--color-primary)}.form-select{cursor:pointer}.alert{padding:var(--space-3);border-radius:var(--radius-lg);font-size:var(--text-sm);border:1px solid transparent}.alert-error{background:var(--color-error-bg);border-color:#ef44444d;color:var(--color-error)}.alert-success{background:var(--color-success-bg);border-color:#10b9814d;color:var(--color-success)}.w-full{width:100%}.mt-2{margin-top:var(--space-2)}.mb-2{margin-bottom:var(--space-2)}.my-4{margin-top:var(--space-4);margin-bottom:var(--space-4)}.op-20{opacity:.2}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-lg{font-size:var(--text-lg)}.text-link{color:var(--color-primary-light);cursor:pointer;background:none;border:none;padding:0}.text-link:hover{text-decoration:underline;color:var(--color-primary)}.font-bold{font-weight:var(--font-bold)}.container-flex{display:flex;align-items:center}.space-y-2>*+*{margin-top:var(--space-2)}.badge{display:inline-flex;align-items:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.05em}.badge-primary{background:#6366f126;color:var(--color-primary-light)}.badge-success{background:var(--color-success-bg);color:var(--color-success)}.badge-warning{background:var(--color-warning-bg);color:var(--color-warning)}.badge-error{background:var(--color-error-bg);color:var(--color-error)}.progress-bar{width:100%;height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-full);transition:width var(--transition-slow)}.lesson-section{margin-bottom:var(--space-8);padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl)}.lesson-section-header{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-4);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.lesson-section-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:var(--radius-md);font-size:var(--text-lg)}.lesson-section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text-primary)}.mental-model{border-left:3px solid var(--color-primary)}.why-exists{border-left:3px solid var(--color-secondary)}.plain-english{border-left:3px solid var(--color-accent)}.syntax-block{border-left:3px solid var(--color-success)}.mistakes-block{border-left:3px solid var(--color-warning)}.practice-block{border-left:3px solid var(--color-info)}.code-toggle{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.code-toggle-btn{flex:1;padding:var(--space-2) var(--space-4);font-size:var(--text-sm);font-weight:var(--font-medium);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.code-toggle-btn.active.wrong{background:var(--color-error-bg);border-color:var(--color-error);color:var(--color-error)}.code-toggle-btn.active.correct{background:var(--color-success-bg);border-color:var(--color-success);color:var(--color-success)}.callout{padding:var(--space-4);border-radius:var(--radius-lg);margin:var(--space-4) 0}.callout-confused{background:var(--color-warning-bg);border:1px solid rgba(245,158,11,.3)}.callout-confused:before{content:"🤔 Why students get confused here";display:block;font-weight:var(--font-semibold);margin-bottom:var(--space-2);color:var(--color-warning)}.callout-tip{background:var(--color-info-bg);border:1px solid rgba(59,130,246,.3)}.callout-exam{background:var(--color-error-bg);border:1px solid rgba(239,68,68,.3)}.callout-exam:before{content:"📝 Exam Important";display:block;font-weight:var(--font-semibold);margin-bottom:var(--space-2);color:var(--color-error)}.code-editor-container{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden}.code-editor-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);background:var(--color-bg-tertiary);border-bottom:1px solid var(--color-border)}.code-editor-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--color-text-secondary)}.code-editor-actions{display:flex;gap:var(--space-2)}.code-output{padding:var(--space-4);background:var(--color-bg-primary);border-top:1px solid var(--color-border);font-family:var(--font-mono);font-size:var(--text-sm);min-height:80px;max-height:200px;overflow-y:auto}.code-output.success{color:var(--color-success)}.code-output.error{color:var(--color-error)}.code-editor-textarea{width:100%;min-height:200px;padding:var(--space-4);font-family:var(--font-mono);font-size:var(--text-sm);line-height:1.6;background:var(--color-bg-secondary);color:var(--color-text-primary);border:none;resize:vertical;outline:none}.code-editor-textarea::placeholder{color:var(--color-text-muted)}.code-editor-textarea:focus{outline:none}@media (min-width: 768px){.code-editor-textarea{min-height:350px;font-size:var(--text-base)}.code-output{max-height:300px}}@media (min-width: 1024px){.code-editor-textarea{min-height:450px}}.nav{position:sticky;top:0;z-index:var(--z-dropdown);background:#0a0a0fe6;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-4)}.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}.nav-logo{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text-primary)}.nav-logo span{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.mobile-nav{position:fixed;bottom:0;left:0;right:0;z-index:var(--z-dropdown);background:#0a0a0ff2;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid var(--color-border);padding:var(--space-2) var(--space-4);padding-bottom:calc(var(--space-2) + env(safe-area-inset-bottom))}.mobile-nav-inner{display:flex;justify-content:space-around;align-items:center}.mobile-nav-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-2);color:var(--color-text-muted);font-size:var(--text-xs);transition:color var(--transition-fast);min-width:60px}.mobile-nav-item.active{color:var(--color-primary-light)}.mobile-nav-item svg{width:24px;height:24px}.sidebar{position:fixed;top:60px;left:0;bottom:0;width:280px;background:var(--color-bg-secondary);border-right:1px solid var(--color-border);overflow-y:auto;overflow-x:hidden;padding:var(--space-4);padding-bottom:var(--space-16);display:none;scrollbar-width:thin;scrollbar-color:var(--color-bg-tertiary) transparent}.sidebar::-webkit-scrollbar{width:6px}.sidebar::-webkit-scrollbar-track{background:transparent}.sidebar::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-full)}.sidebar::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}@media (min-width: 1024px){.sidebar{display:block;transition:transform .3s var(--ease-out-expo),opacity .3s ease}.sidebar.closed{transform:translate(-100%);opacity:0;pointer-events:none}.main-content{margin-left:280px;width:calc(100% - 280px);padding-top:60px;transition:margin-left .3s var(--ease-out-expo),width .3s var(--ease-out-expo)}.main-content.no-sidebar{margin-left:0;width:100%;padding-top:0}.main-content.sidebar-closed{margin-left:0;width:100%}}.auth-view .main-content{padding-top:0;min-height:100vh;display:block}.sidebar-section{margin-bottom:var(--space-1)}.sidebar-section:last-child{margin-bottom:var(--space-8)}.sidebar-quick-nav{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3)}.sidebar-quick-link{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);text-decoration:none;transition:all .2s var(--ease-out-quart)}.sidebar-quick-link:hover{background:var(--color-bg-glass);color:var(--color-text-primary)}.sidebar-divider{height:1px;background:var(--color-border);margin:var(--space-3) 0}.sidebar-phase-header{display:flex;align-items:center;width:100%;padding:var(--space-3);background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s var(--ease-out-quart);margin-bottom:var(--space-1)}.sidebar-phase-header:hover{background:#6366f11a;border-color:#6366f14d}.sidebar-phase-header.active{background:linear-gradient(135deg,#6366f126,#8b5cf61a);border-color:var(--color-primary)}.sidebar-phase-header.complete{border-color:var(--color-success)}.sidebar-phase-icon{font-size:var(--text-lg);margin-right:var(--space-2)}.sidebar-phase-title{flex:1;text-align:left;font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--color-text-primary)}.sidebar-phase-subtitle{display:block;font-size:var(--text-xs);font-weight:var(--font-normal);color:var(--color-text-muted);margin-top:2px}.sidebar-phase-progress{font-size:var(--text-xs);color:var(--color-text-muted);margin-right:var(--space-2)}.sidebar-phase-arrow{color:var(--color-text-muted);transition:transform .2s var(--ease-out-quart)}.sidebar-phase-arrow.expanded{transform:rotate(180deg)}.sidebar-lessons{padding-left:var(--space-2);margin-bottom:var(--space-2);animation:slideDown .2s var(--ease-out-quart)}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.sidebar-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);margin-bottom:2px;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--text-sm);transition:all .15s var(--ease-out-quart);cursor:pointer;text-decoration:none;border-left:2px solid transparent}.sidebar-item:hover{background:var(--color-bg-glass);color:var(--color-text-primary);border-left-color:var(--color-border-light)}.sidebar-item.active{background:linear-gradient(135deg,#6366f126,#8b5cf61a);color:var(--color-primary-light);border-left-color:var(--color-primary)}.sidebar-item.completed,.sidebar-item.completed .sidebar-item-icon{color:var(--color-success)}.sidebar-item-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-item-dot{width:6px;height:6px;border-radius:50%;background:var(--color-border-light)}.sidebar-item.active .sidebar-item-dot{background:var(--color-primary)}.sidebar-item-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.container{width:100%;max-width:800px;margin:0 auto;padding:var(--space-4)}@media (min-width: 768px){.container{padding:var(--space-8)}}.main-content{flex:1;padding-bottom:100px;width:100%;overflow:visible}@media (min-width: 1024px){.main-content{padding-bottom:var(--space-8);height:calc(100vh - 60px);overflow-y:auto;overflow-x:hidden}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(.98)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.animate-fadeIn{animation:fadeIn .5s var(--ease-out-expo) forwards}.animate-slideUp{animation:slideUp .6s var(--ease-out-expo) forwards}.animate-scaleIn{animation:scaleIn .4s var(--ease-out-expo) forwards}.lesson-section{animation:slideUp .5s var(--ease-out-expo) forwards;opacity:0}.lesson-section:nth-child(1){animation-delay:.1s}.lesson-section:nth-child(2){animation-delay:.2s}.lesson-section:nth-child(3){animation-delay:.3s}.lesson-section:nth-child(4){animation-delay:.4s}.lesson-section:nth-child(5){animation-delay:.5s}.lesson-section:nth-child(6){animation-delay:.6s}.card,.card-glass{transition:transform .4s var(--ease-out-expo),box-shadow .4s var(--ease-out-expo),border-color .3s var(--ease-out-quart)}.card:hover{transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.btn{transition:transform .3s var(--ease-out-expo),box-shadow .3s var(--ease-out-expo),background .3s var(--ease-out-quart)}.btn:active{transform:scale(.97)}.btn-primary:hover{transform:translateY(-3px) scale(1.02)}.sidebar-item{transition:all .25s var(--ease-out-quart)}.sidebar-item:hover{transform:translate(4px)}.mobile-nav-item{transition:all .25s var(--ease-out-expo)}.mobile-nav-item:active{transform:scale(.92)}.progress-bar-fill{transition:width .8s var(--ease-out-expo)}.input{transition:all .3s var(--ease-out-expo)}.input:focus{transform:scale(1.01);box-shadow:0 0 0 4px #6366f126}.code-toggle-btn{transition:all .25s var(--ease-out-quart)}.code-toggle-btn:hover{transform:translateY(-2px)}.badge{transition:all .2s var(--ease-out-quart)}.badge:hover{transform:scale(1.05)}.container{animation:fadeIn .4s var(--ease-out-expo) forwards}.skeleton{background:linear-gradient(90deg,var(--color-bg-tertiary) 0%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.hidden{display:none}@media (min-width: 768px){.md\:flex{display:flex}.md\:hidden{display:none}}@media (min-width: 1024px){.lg\:flex{display:flex}.lg\:hidden{display:none}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}::selection{background:#6366f14d;color:var(--color-text-primary)}.sidebar-toggle-fab{position:fixed;bottom:24px;left:24px;width:56px;height:56px;border-radius:50%;background:#0f0f1499;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);color:var(--color-text-primary);cursor:pointer;z-index:1000;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px #0000004d;overflow:hidden}.sidebar-toggle-fab:hover{transform:scale(1.1);background:#14141ecc;border-color:#6366f166;box-shadow:0 8px 24px #6366f140}.sidebar-toggle-fab:active{transform:scale(.95)}.sidebar-toggle-icon{position:relative;z-index:2;transition:transform .4s ease}.sidebar-toggle-fab:hover .sidebar-toggle-icon{transform:rotate(180deg)}.toggle-svg path{transition:d .3s ease,transform .3s ease;transform-origin:center}.sidebar-toggle-glow{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at center,rgba(99,102,241,.4),transparent 70%);opacity:0;transition:opacity .3s ease;pointer-events:none;z-index:1}.sidebar-toggle-fab:hover .sidebar-toggle-glow{opacity:1}@media (max-width: 1023px){.sidebar-toggle-fab{display:none}}@media (min-width: 1024px){.grid-desktop-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-6)}:root{--text-xs: .8rem;--text-sm: .95rem;--text-base: 1.1rem;--text-lg: 1.25rem;--text-xl: 1.5rem;--text-2xl: 2rem;--text-3xl: 2.5rem;--text-4xl: 3.5rem}h1{font-size:var(--text-4xl);margin-bottom:var(--space-8)}h2{font-size:var(--text-3xl);margin-bottom:var(--space-6)}h3{font-size:var(--text-2xl);margin-bottom:var(--space-4)}.container{max-width:1200px;padding-left:var(--space-8);padding-right:var(--space-8)}}.hover-premium{position:relative;transition:all .4s var(--ease-out-expo);z-index:1}.hover-premium:after{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-radius:inherit;z-index:-1;opacity:0;transition:opacity .4s var(--ease-out-expo)}.hover-premium:hover{transform:translateY(-8px) scale(1.02);box-shadow:0 20px 40px #0006,0 0 20px #6366f133;border-color:transparent}.hover-premium:hover:after{opacity:.2}.phases-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media (min-width: 768px){.phases-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width: 1280px){.phases-grid{grid-template-columns:repeat(3,1fr)}}.streak-compact{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);background:var(--color-bg-tertiary);border-radius:var(--radius-full);font-weight:var(--font-semibold)}.streak-compact .streak-count{font-size:var(--text-sm);color:var(--color-text-primary)}.streak-display{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:linear-gradient(135deg,#f973161a,#ea580c1a);border:1px solid rgba(249,115,22,.3);border-radius:var(--radius-xl)}.streak-display.inactive{background:var(--color-bg-tertiary);border-color:var(--color-border)}.streak-flame-container{font-size:2.5rem;line-height:1}.streak-flame{display:inline-block;animation:flameGlow 1.5s ease-in-out infinite alternate}.streak-flame.inactive{filter:grayscale(100%);opacity:.5;animation:none}@keyframes flameGlow{0%{transform:scale(1);filter:drop-shadow(0 0 5px rgba(249,115,22,.5))}to{transform:scale(1.1);filter:drop-shadow(0 0 15px rgba(249,115,22,.8))}}.streak-info{display:flex;flex-direction:column}.streak-count-large{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text-primary);line-height:1}.streak-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.streak-warning{margin-left:auto;padding:var(--space-2) var(--space-3);background:var(--color-warning-bg);border-radius:var(--radius-md);font-size:var(--text-xs);color:var(--color-warning)}.badge-container{display:flex;flex-wrap:wrap;gap:var(--space-3)}.achievement-badge{display:flex;flex-direction:column;align-items:center;gap:var(--space-1);padding:var(--space-3);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);min-width:80px;transition:all var(--transition-fast)}.achievement-badge:hover{transform:translateY(-2px);border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.achievement-badge.locked{opacity:.4;filter:grayscale(100%)}.achievement-badge .badge-icon{font-size:1.5rem}.achievement-badge .badge-name{font-size:var(--text-xs);text-align:center;color:var(--color-text-secondary)}.achievement-popup{position:fixed;top:20%;left:50%;transform:translate(-50%);z-index:var(--z-toast);background:linear-gradient(135deg,var(--color-bg-card),var(--color-bg-secondary));border:2px solid var(--color-primary);border-radius:var(--radius-2xl);padding:var(--space-6);text-align:center;box-shadow:0 20px 40px #00000080,var(--shadow-glow);animation:popupSlide .5s var(--ease-out-expo)}@keyframes popupSlide{0%{opacity:0;transform:translate(-50%) translateY(-30px) scale(.9)}to{opacity:1;transform:translate(-50%) translateY(0) scale(1)}}.achievement-popup .popup-icon{font-size:4rem;margin-bottom:var(--space-4);animation:celebrate .6s ease-out}@keyframes celebrate{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.achievement-popup .popup-title{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-primary-light);margin-bottom:var(--space-2)}.achievement-popup .popup-desc{color:var(--color-text-secondary);margin-bottom:var(--space-4)}.user-dropdown{position:relative}.user-dropdown-trigger{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);background:var(--color-bg-glass);border:1px solid var(--color-border);border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-primary)}.user-dropdown-trigger:hover{background:var(--color-bg-tertiary);border-color:var(--color-border-light)}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));display:flex;align-items:center;justify-content:center;font-size:var(--text-sm);font-weight:var(--font-bold);color:#fff}.user-avatar.large{width:48px;height:48px;font-size:var(--text-lg)}.user-name{font-size:var(--text-sm);max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{transition:transform var(--transition-fast);color:var(--color-text-muted)}.dropdown-arrow.open{transform:rotate(180deg)}.user-dropdown-menu{position:absolute;top:calc(100% + 8px);right:0;min-width:240px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);animation:dropdownSlide .2s var(--ease-out-expo);overflow:hidden}@keyframes dropdownSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.dropdown-header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-bg-tertiary)}.user-info{overflow:hidden}.user-fullname{font-weight:var(--font-semibold);color:var(--color-text-primary)}.user-email{font-size:var(--text-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-divider{height:1px;background:var(--color-border);margin:0}.dropdown-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;color:var(--color-text-secondary);font-size:var(--text-sm);cursor:pointer;transition:all var(--transition-fast);text-align:left}.dropdown-item:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.dropdown-item.danger:hover{background:var(--color-error-bg);color:var(--color-error)}.dropdown-icon{display:flex;align-items:center;justify-content:center;width:20px}.dropdown-badge{margin-left:auto;padding:var(--space-1) var(--space-2);background:var(--color-bg-tertiary);border-radius:var(--radius-sm);font-size:var(--text-xs);text-transform:capitalize}.achievements-container{display:flex;flex-direction:column;gap:var(--space-4)}.achievement-summary{text-align:center;padding-top:var(--space-3);border-top:1px solid var(--color-border)}.achievement-progress{font-size:var(--text-sm);color:var(--color-text-secondary)}.achievement-badge{position:relative}.achievement-badge .badge-lock{position:absolute;top:-5px;right:-5px;font-size:.7rem;opacity:.8}.achievement-badge.unlocked{opacity:1}.badge-compact{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-lg)}.badge-compact .badge-count{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-primary)}.badge-compact .badge-label{font-size:var(--text-sm);color:var(--color-text-muted)}.playground-container{padding:var(--space-6);max-width:1000px;margin:0 auto}.playground-header{margin-bottom:var(--space-6)}.playground-templates{display:flex;align-items:flex-start;gap:var(--space-2);flex-wrap:wrap}.template-buttons{display:flex;flex-wrap:wrap;gap:var(--space-2)}.template-btn{padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.template-btn:hover{background:var(--color-bg-card);border-color:var(--color-border-light);color:var(--color-text-primary)}.template-btn.active{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));border-color:var(--color-primary);color:#fff}.playground-editor{border-radius:var(--radius-xl);overflow:hidden}.playground-tips{display:flex;flex-wrap:wrap;gap:var(--space-3)}.tip-card{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-bg-tertiary);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text-secondary)}.tip-card kbd{padding:var(--space-1) var(--space-2);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:var(--text-xs)}.grid-desktop-3{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media (min-width: 768px){.grid-desktop-3{grid-template-columns:repeat(3,1fr)}}.analytics-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--space-5);background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-xl);transition:all var(--transition-fast)}.analytics-card:hover{border-color:var(--color-primary);transform:translateY(-2px)}.analytics-icon{font-size:2rem;margin-bottom:var(--space-2)}.analytics-value{font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--color-text-primary)}.analytics-label{font-size:var(--text-sm);color:var(--color-text-secondary)}.time-estimate{text-align:center}.time-remaining{margin-bottom:var(--space-2)}.time-value{font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--color-primary)}.time-label{font-size:var(--text-base);color:var(--color-text-secondary)}.lessons-remaining{font-size:var(--text-sm);color:var(--color-text-muted)}.insight-card{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);border-radius:var(--radius-xl)}.insight-card.success{background:var(--color-success-bg);border:1px solid rgba(16,185,129,.3)}.insight-card.warning{background:var(--color-warning-bg);border:1px solid rgba(245,158,11,.3)}.insight-icon{font-size:2rem}.insight-title{font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:var(--space-1)}.insight-value{font-weight:var(--font-semibold);color:var(--color-text-primary)}.insight-desc{font-size:var(--text-sm);color:var(--color-text-secondary)}.lesson-notes{margin-bottom:var(--space-6);border-radius:var(--radius-xl);background:var(--color-bg-card);border:1px solid var(--color-border);overflow:hidden}.lesson-notes-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-3) var(--space-4);background:none;border:none;cursor:pointer;transition:background var(--transition-fast)}.lesson-notes-header:hover{background:var(--color-bg-tertiary)}.notes-header-content{display:flex;align-items:center;gap:var(--space-2)}.notes-icon{font-size:1.2rem}.notes-title{font-weight:var(--font-semibold);color:var(--color-text-primary)}.notes-badge{font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background:var(--color-bg-tertiary);border-radius:var(--radius-full);color:var(--color-text-muted)}.notes-arrow{transition:transform var(--transition-fast);color:var(--color-text-muted)}.notes-arrow.open{transform:rotate(180deg)}.lesson-notes-content{padding:0 var(--space-4) var(--space-4)}.notes-textarea{width:100%;min-height:150px;padding:var(--space-3);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-primary);font-size:var(--text-sm);line-height:1.6;resize:vertical;transition:border-color var(--transition-fast)}.notes-textarea:focus{outline:none;border-color:var(--color-primary)}.notes-textarea::placeholder{color:var(--color-text-muted)}.notes-footer{display:flex;align-items:center;justify-content:space-between;margin-top:var(--space-2)}.notes-status{font-size:var(--text-xs)}.notes-status.saved{color:var(--color-success)}.notes-status.saving{color:var(--color-warning)}html,body,#root,.app{height:auto!important;min-height:100vh!important;overflow-y:visible!important;overflow-x:hidden;position:static!important}.main-content{height:auto!important;min-height:0!important;flex:1;overflow:visible!important;padding-bottom:120px!important}.phases-grid{display:flex!important;flex-direction:column!important;gap:var(--space-4);height:auto!important;overflow:visible!important}@media (min-width: 768px){.phases-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important}}@media (min-width: 1280px){.phases-grid{grid-template-columns:repeat(3,1fr)!important}}
