@import "https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@400;500&display=swap";
:root{--bg-deep:#0a0c10;--bg-surface:#12151c;--bg-card:#1a1e28;--bg-card-hover:#222836;--bg-elevated:#252b3a;--border:#2a3040;--border-light:#3a4258;--text-primary:#e8ecf4;--text-secondary:#8b95aa;--text-muted:#5a6478;--green:#65d26e;--green-dim:#3a7a40;--green-glow:#65d26e26;--amber:#f5a623;--amber-dim:#8a6020;--amber-glow:#f5a62326;--blue:#4ba3f5;--purple:#a78bfa;--red:#f05454;--red-dim:#8a2020;--red-glow:#f0545426;--cyan:#22d3ee;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--max-width:1100px;--shadow-card:0 4px 20px #0000004d;--shadow-glow-green:0 0 20px #65d26e33;--shadow-glow-amber:0 0 20px #f5a62333}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{background:var(--bg-deep);color:var(--text-primary);-webkit-font-smoothing:antialiased;min-height:100vh;font-family:Inter,system-ui,sans-serif}h1,h2,h3,h4,h5{font-family:Outfit,sans-serif;font-weight:700}a{color:inherit;text-decoration:none}.navbar{z-index:100;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#12151cd9;justify-content:space-between;align-items:center;height:64px;padding:0 24px;display:flex;position:sticky;top:0}.navbar-brand{align-items:center;gap:10px;font-family:Outfit,sans-serif;font-size:1.3rem;font-weight:800;display:flex}.navbar-brand span{color:var(--green)}.brand-bang{margin-left:-2px}.navbar-stats{align-items:center;gap:20px;display:flex}.navbar-stat{color:var(--text-secondary);align-items:center;gap:6px;font-size:.85rem;font-weight:500;display:flex}.navbar-stat .value{color:var(--text-primary);font-weight:600}.navbar-links{gap:4px;display:flex}.navbar-link{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:8px 14px;font-size:.85rem;font-weight:500;transition:all .2s;display:flex}.navbar-link:hover,.navbar-link.active{color:var(--text-primary);background:var(--bg-card)}.xp-bar-container{background:var(--bg-elevated);border-radius:3px;width:120px;height:6px;overflow:hidden}.xp-bar-fill{background:linear-gradient(90deg, var(--green), var(--cyan));border-radius:3px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.streak-flame{align-items:center;gap:4px;font-size:.85rem;font-weight:600;display:flex}.streak-flame.active{color:var(--amber)}.streak-flame .flame-icon{font-size:1.1rem;animation:1.5s ease-in-out infinite alternate flicker}@keyframes flicker{0%{opacity:.8;transform:scale(1)rotate(-3deg)}to{opacity:1;transform:scale(1.1)rotate(3deg)}}.page-container{max-width:var(--max-width);margin:0 auto;padding:32px 24px 64px}.page-header{margin-bottom:32px}.page-header h1{margin-bottom:8px;font-size:2rem}.page-header p{color:var(--text-secondary);font-size:1rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:all .25s}.card:hover{border-color:var(--border-light)}.card-glow-green{box-shadow:var(--shadow-glow-green);border-color:var(--green-dim)}.card-glow-amber{box-shadow:var(--shadow-glow-amber);border-color:var(--amber-dim)}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{flex-direction:column;gap:8px;display:flex}.stat-card .stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:600}.stat-card .stat-value{font-family:Outfit,sans-serif;font-size:1.8rem;font-weight:800}.stat-card .stat-sub{color:var(--text-secondary);font-size:.8rem}.dungeon-map{flex-direction:column;align-items:center;gap:0;display:flex;position:relative}.map-floor{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);cursor:pointer;align-items:center;gap:20px;width:100%;max-width:600px;padding:16px 20px;transition:all .3s;display:flex;position:relative}.map-floor:hover:not(.locked){border-color:var(--green-dim);background:var(--bg-card-hover);transform:translate(4px)}.map-floor.locked{opacity:.4;cursor:not-allowed}.map-floor.completed{border-color:var(--green-dim)}.map-floor .floor-icon{text-align:center;width:48px;font-size:2rem}.map-floor .floor-info{flex:1}.map-floor .floor-number{color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;font-size:.7rem;font-weight:600}.map-floor .floor-title{font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700}.map-floor .floor-subtitle{color:var(--text-secondary);font-size:.82rem}.map-floor .floor-badge{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;padding:3px 10px;font-size:.7rem;font-weight:600}.map-floor .floor-badge.completed-badge{background:var(--green-glow);color:var(--green)}.map-floor .floor-badge.available-badge{background:var(--amber-glow);color:var(--amber)}.map-floor .floor-badge.locked-badge{color:var(--text-muted);background:#5a647833}.map-connector{background:var(--border);width:2px;height:24px;margin:0 auto}.map-connector.active{background:var(--green-dim)}.floor-header{align-items:center;gap:16px;margin-bottom:32px;display:flex}.floor-header .floor-icon-lg{font-size:3rem}.floor-header .difficulty-tag{text-transform:uppercase;letter-spacing:.05em;border-radius:20px;margin-top:4px;padding:2px 10px;font-size:.7rem;font-weight:600;display:inline-block}.difficulty-Beginner{background:var(--green-glow);color:var(--green)}.difficulty-Intermediate{background:var(--amber-glow);color:var(--amber)}.difficulty-Advanced{background:var(--red-glow);color:var(--red)}.room-list{flex-direction:column;gap:12px;display:flex}.room-card{cursor:pointer;align-items:center;gap:16px;padding:18px 20px;display:flex}.room-card:hover:not(.room-locked){border-color:var(--green-dim);transform:translate(4px)}.room-card.room-locked{opacity:.4;cursor:not-allowed}.room-card .room-status{border:2px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:1rem;display:flex}.room-card .room-status.done{background:var(--green-glow);border-color:var(--green);color:var(--green)}.room-card .room-status.available{border-color:var(--amber);color:var(--amber)}.room-card .room-title{font-size:1rem;font-weight:600}.room-card .room-xp{color:var(--green);margin-left:auto;font-size:.8rem;font-weight:600}.boss-btn{border:2px solid var(--amber-dim);border-radius:var(--radius-lg);background:var(--amber-glow);width:100%;max-width:600px;color:var(--amber);cursor:pointer;justify-content:center;align-items:center;gap:10px;margin:32px auto 0;padding:16px 24px;font-family:Outfit,sans-serif;font-size:1.1rem;font-weight:700;transition:all .3s;display:flex}.boss-btn:hover:not(:disabled){box-shadow:var(--shadow-glow-amber);background:#f5a62340;transform:scale(1.02)}.boss-btn:disabled{opacity:.3;cursor:not-allowed}.lesson-container{max-width:720px;margin:0 auto}.lesson-content{margin-bottom:40px}.lesson-content p{color:var(--text-secondary);margin-bottom:16px;font-size:1rem;line-height:1.75}.lesson-code-block{border:1px solid var(--border);border-radius:var(--radius-md);background:#0d1117;margin:16px 0;overflow:hidden}.lesson-code-label{color:var(--text-muted);border-bottom:1px solid var(--border);letter-spacing:.03em;text-transform:uppercase;padding:8px 16px;font-size:.75rem;font-weight:600}.lesson-code-block pre{color:var(--green);padding:16px;font-family:JetBrains Mono,monospace;font-size:.85rem;line-height:1.6;overflow-x:auto}.lesson-pro-tip{border-left:3px solid var(--amber);background:var(--amber-glow);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary);margin:20px 0;padding:16px 20px;font-size:.9rem}.lesson-pro-tip:before{content:"💡 Pro Tip";color:var(--amber);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.8rem;font-weight:700;display:block}.challenge-section{border-top:1px solid var(--border);margin-top:32px;padding-top:32px}.challenge-title{margin-bottom:8px;font-family:Outfit,sans-serif;font-size:1.4rem;font-weight:700}.challenge-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.9rem}.hp-bar{gap:6px;margin-bottom:24px;display:flex}.hp-heart{font-size:1.3rem;transition:all .3s}.hp-heart.lost{opacity:.2;transform:scale(.8)}.quiz-question{margin-bottom:16px;font-size:1.05rem;font-weight:600;line-height:1.5}.quiz-options{flex-direction:column;gap:10px;display:flex}.quiz-option{border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;background:var(--bg-card);align-items:center;gap:12px;padding:14px 18px;font-size:.95rem;transition:all .2s;display:flex}.quiz-option:hover:not(.selected):not(.disabled){border-color:var(--border-light);background:var(--bg-card-hover)}.quiz-option.correct{border-color:var(--green);background:var(--green-glow);color:var(--green)}.quiz-option.incorrect{border-color:var(--red);background:var(--red-glow);color:var(--red)}.quiz-option.disabled{cursor:default;opacity:.6}.quiz-option .option-letter{border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.8rem;font-weight:600;display:flex}.quiz-explanation{background:var(--bg-elevated);border-radius:var(--radius-md);color:var(--text-secondary);margin-top:16px;padding:14px 18px;font-size:.9rem;line-height:1.5}.dnd-container{flex-direction:column;gap:20px;display:flex}.dnd-zones{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.dnd-zone{border:2px dashed var(--border);border-radius:var(--radius-md);min-height:80px;padding:16px;transition:all .2s}.dnd-zone.drag-over{border-color:var(--green);background:var(--green-glow)}.dnd-zone .zone-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:.8rem;font-weight:600}.dnd-items{flex-wrap:wrap;gap:8px;display:flex}.dnd-item{background:var(--bg-elevated);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:grab;-webkit-user-select:none;user-select:none;padding:8px 14px;font-size:.85rem;font-weight:500;transition:all .2s}.dnd-item:active{cursor:grabbing}.dnd-item.correct-item{border-color:var(--green);background:var(--green-glow);color:var(--green)}.dnd-item.incorrect-item{border-color:var(--red);background:var(--red-glow);color:var(--red)}.fill-blank-prompt{margin-bottom:16px;font-size:1rem;font-weight:600;line-height:1.5}.fill-blank-template{border:1px solid var(--border);border-radius:var(--radius-md);color:var(--green);background:#0d1117;padding:20px;font-family:JetBrains Mono,monospace;font-size:.9rem;line-height:2}.fill-blank-input{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-primary);border-radius:4px;outline:none;width:120px;padding:2px 8px;font-family:JetBrains Mono,monospace;font-size:.85rem;transition:border-color .2s}.fill-blank-input:focus{border-color:var(--green)}.fill-blank-input.correct-input{border-color:var(--green);color:var(--green)}.fill-blank-input.incorrect-input{border-color:var(--red);color:var(--red)}.btn{border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:Outfit,sans-serif;font-size:.95rem;font-weight:600;transition:all .25s;display:inline-flex}.btn-primary{background:var(--green);color:var(--bg-deep)}.btn-primary:hover{box-shadow:var(--shadow-glow-green);background:#78e080;transform:translateY(-1px)}.btn-secondary{background:var(--bg-elevated);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-light)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;width:90%;max-width:420px;padding:40px;animation:.4s cubic-bezier(.22,1,.36,1) scaleIn}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.modal-icon{margin-bottom:16px;font-size:4rem}.modal-title{margin-bottom:8px;font-family:Outfit,sans-serif;font-size:1.6rem;font-weight:800}.modal-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:1rem}.badge-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;display:grid}.badge-card{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:20px;display:flex}.badge-card.locked{opacity:.25;filter:grayscale()}.badge-card .badge-icon{font-size:2.2rem}.badge-card .badge-name{font-size:.85rem;font-weight:600}.badge-card .badge-desc{color:var(--text-muted);font-size:.75rem}.progress-bar-container{background:var(--bg-elevated);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--green), var(--cyan));border-radius:4px;height:100%;transition:width .6s cubic-bezier(.22,1,.36,1)}.xp-reward{background:var(--green-glow);color:var(--green);border-radius:20px;align-items:center;gap:6px;padding:8px 16px;font-family:Outfit,sans-serif;font-size:1rem;font-weight:700;animation:.4s cubic-bezier(.22,1,.36,1) popIn;display:inline-flex}@keyframes popIn{0%{opacity:0;transform:scale(0)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.back-link{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:24px;font-size:.9rem;font-weight:500;transition:color .2s;display:inline-flex}.back-link:hover{color:var(--text-primary)}.profile-header{align-items:center;gap:24px;margin-bottom:32px;display:flex}.profile-avatar{background:linear-gradient(135deg, var(--green), var(--cyan));border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:2.2rem;display:flex}.profile-info h1{margin-bottom:4px;font-size:1.6rem}.profile-info .title-tag{border-radius:20px;padding:3px 12px;font-size:.8rem;font-weight:600;display:inline-block}.section-header{margin-top:8px;margin-bottom:16px;font-family:Outfit,sans-serif;font-size:1.2rem;font-weight:700}.completed-overlay{text-align:center;padding:32px}.completed-overlay .completed-icon{margin-bottom:12px;font-size:3rem}.completed-overlay h3{margin-bottom:8px;font-size:1.3rem}.completed-overlay p{color:var(--text-secondary);margin-bottom:20px}.timer{color:var(--amber);align-items:center;gap:8px;font-family:JetBrains Mono,monospace;font-size:1.2rem;font-weight:600;display:flex}.timer.danger{color:var(--red);animation:.5s ease-in-out infinite pulse}@keyframes pulse{0%{transform:scale(1)}to{transform:scale(1.05)}}.spl-terminal-container{margin-top:16px}.spl-prompt{margin-bottom:16px;font-size:1.05rem;font-weight:600;line-height:1.5}.spl-terminal{border:1px solid var(--border);border-radius:var(--radius-md);background:#0d1117;overflow:hidden}.spl-terminal-header{border-bottom:1px solid var(--border);background:#161b22;align-items:center;gap:12px;padding:10px 16px;display:flex}.spl-terminal-dots{gap:6px;display:flex}.spl-terminal-dots .dot{border-radius:50%;width:10px;height:10px}.spl-terminal-dots .dot.red{background:#ff5f57}.spl-terminal-dots .dot.yellow{background:#febc2e}.spl-terminal-dots .dot.green{background:#28c840}.spl-terminal-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.75rem;font-weight:600}.spl-terminal-body{padding:16px}.spl-input-row{align-items:flex-start;gap:8px;display:flex}.spl-caret{color:var(--green);-webkit-user-select:none;user-select:none;font-family:JetBrains Mono,monospace;font-size:1.1rem;font-weight:700;line-height:1.5}.spl-input{color:var(--green);resize:none;caret-color:var(--green);background:0 0;border:none;outline:none;flex:1;font-family:JetBrains Mono,monospace;font-size:.9rem;line-height:1.5}.spl-input::placeholder{color:var(--text-muted)}.spl-input:disabled{opacity:.8;cursor:default}.spl-feedback{border-radius:var(--radius-sm);align-items:flex-start;gap:10px;margin-top:12px;padding:12px 14px;font-size:.9rem;display:flex}.spl-feedback.error{background:var(--red-glow);color:var(--red);border:1px solid #f054544d}.spl-feedback.success{background:var(--green-glow);color:var(--green);border:1px solid #65d26e4d}.spl-feedback-icon{flex-shrink:0;font-size:1.1rem;font-weight:700}.spl-missing-token{color:var(--red);background:#f0545433;border-radius:3px;margin:0 3px;padding:1px 6px;font-family:JetBrains Mono,monospace;font-size:.82rem}.spl-hint{background:var(--amber-glow);border-left:3px solid var(--amber);border-radius:0 var(--radius-sm) var(--radius-sm) 0;color:var(--text-secondary);margin-top:12px;padding:12px 16px;font-size:.88rem}.spl-sample-answer{margin-top:16px}.spl-sample-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:.75rem;font-weight:600}.spl-sample-code{border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--cyan);background:#0d1117;padding:12px 16px;font-family:JetBrains Mono,monospace;font-size:.85rem;line-height:1.5;overflow-x:auto}@media (max-width:768px){.navbar{height:56px;padding:0 12px}.navbar-brand{gap:6px;font-size:1.1rem}.navbar-stats{display:none}.navbar-links{gap:2px}.navbar-link{gap:4px;padding:6px 10px;font-size:.8rem}.page-container{padding:16px 12px 48px}.page-header{margin-bottom:20px}.page-header h1{font-size:1.5rem}.page-header p{font-size:.9rem}.stat-grid{grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:20px}.stat-card{padding:16px}.stat-card .stat-value{font-size:1.5rem}.card{border-radius:var(--radius-md);padding:16px}.course-actions{flex-direction:column!important;width:100%!important}.map-floor{gap:12px;padding:12px 14px}.map-floor .floor-icon{width:36px;font-size:1.6rem}.map-floor .floor-title{font-size:1rem}.map-floor .floor-subtitle{font-size:.78rem}.room-card{gap:12px;padding:14px}.room-card .room-status{width:30px;height:30px;font-size:.85rem}.lesson-container{max-width:100%}.lesson-content p{font-size:.95rem}.lesson-code-block pre{padding:12px;font-size:.78rem}.fill-blank-template{padding:12px;font-size:.82rem}.fill-blank-input{width:90px;font-size:.78rem}.quiz-option{padding:12px 14px;font-size:.9rem}.quiz-option .option-letter{width:24px;height:24px;font-size:.75rem}.dnd-zones{grid-template-columns:1fr}.dnd-item{padding:6px 10px;font-size:.8rem}.badge-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}.badge-card{padding:14px}.badge-card .badge-icon{font-size:1.8rem}.badge-card .badge-name{font-size:.8rem}.profile-header{text-align:center;flex-direction:column;gap:16px}.profile-avatar{width:64px;height:64px;font-size:1.8rem}.profile-info h1{font-size:1.3rem}.boss-btn{padding:12px 16px;font-size:1rem}.modal-content{max-width:92%;padding:24px}.modal-icon{font-size:3rem}.modal-title{font-size:1.3rem}.exam-sidebar{z-index:50;flex-wrap:nowrap;align-items:center;gap:12px;box-shadow:0 -4px 20px #0006;border-radius:var(--radius-lg) var(--radius-lg) 0 0!important;width:100%!important;padding:12px 16px!important;display:flex!important;position:fixed!important;top:auto!important;bottom:0!important;left:0!important}.exam-sidebar .timer{margin-bottom:0!important;font-size:1rem!important}.exam-sidebar .question-grid{display:none!important}.exam-sidebar .submit-btn{flex:1;margin-top:0!important}.exam-main{padding-bottom:80px!important}.section-header{font-size:1.05rem}.challenge-title{font-size:1.2rem}}@media (max-width:480px){.navbar{height:48px;padding:0 8px}.navbar-brand{font-size:1rem}.navbar-link{padding:5px 8px;font-size:.75rem}.navbar-link span.link-label{display:none}.page-container{padding:12px 8px 40px}.page-header h1{font-size:1.3rem}.stat-grid{grid-template-columns:repeat(2,1fr);gap:6px}.stat-card{gap:4px;padding:12px}.stat-card .stat-label{font-size:.7rem}.stat-card .stat-value{font-size:1.2rem}.stat-card .stat-sub{font-size:.7rem}.card{border-radius:var(--radius-sm);padding:12px}.map-floor{border-radius:var(--radius-md);gap:10px;padding:10px 12px}.map-floor .floor-icon{width:30px;font-size:1.4rem}.map-floor .floor-title{font-size:.9rem}.map-floor .floor-number{font-size:.65rem}.map-floor .floor-badge{padding:2px 6px;font-size:.6rem}.quiz-option{gap:8px;padding:10px 12px;font-size:.85rem}.quiz-question{font-size:.95rem}.badge-grid{grid-template-columns:repeat(3,1fr);gap:6px}.badge-card{padding:10px}.badge-card .badge-icon{font-size:1.5rem}.badge-card .badge-name{font-size:.72rem}.badge-card .badge-desc{display:none}.btn{padding:10px 16px;font-size:.85rem}.boss-btn{padding:10px 12px;font-size:.9rem}.lesson-code-block pre{font-size:.72rem}.fill-blank-template{font-size:.76rem}.fill-blank-input{width:70px}.back-link{margin-bottom:16px;font-size:.82rem}.floor-header .floor-icon-lg{font-size:2rem}.xp-reward{padding:6px 12px;font-size:.85rem}}@keyframes shake{0%{transform:translate(1px,1px)rotate(0)}10%{transform:translate(-1px,-2px)rotate(-1deg)}20%{transform:translate(-3px)rotate(1deg)}30%{transform:translate(3px,2px)rotate(0)}40%{transform:translate(1px,-1px)rotate(1deg)}50%{transform:translate(-1px,2px)rotate(-1deg)}60%{transform:translate(-3px,1px)rotate(0)}70%{transform:translate(3px,1px)rotate(-1deg)}80%{transform:translate(-1px,-1px)rotate(1deg)}90%{transform:translate(1px,2px)rotate(0)}to{transform:translate(1px,-2px)rotate(-1deg)}}.shake{animation:.3s cubic-bezier(.36,.07,.19,.97) both shake}.analytics-course-row{border-bottom:1px solid var(--border);align-items:center;gap:16px;padding:12px 0;display:flex}.analytics-course-row:last-child{border-bottom:none}.analytics-course-label{align-items:center;gap:8px;min-width:180px;font-size:.9rem;font-weight:600;display:flex}.analytics-badge{background:var(--green-glow);color:var(--green);border-radius:4px;padding:2px 8px;font-size:.7rem;font-weight:700}.analytics-bar-container{flex:1;align-items:center;gap:12px;display:flex}.analytics-bar-track{background:var(--bg-deep);border-radius:6px;flex:1;height:12px;display:flex;overflow:hidden}.analytics-bar-correct{background:linear-gradient(90deg, var(--green), #4ade80);height:100%;transition:width .6s}.analytics-bar-wrong{background:linear-gradient(90deg, var(--red), #f87171);height:100%;transition:width .6s}.analytics-bar-empty{background:var(--border);width:100%;height:100%}.analytics-bar-label{color:var(--text-muted);white-space:nowrap;text-align:right;min-width:120px;font-size:.8rem}.analytics-topics{flex-direction:column;gap:2px;display:flex}.analytics-topic-row{border-radius:var(--radius-sm);align-items:center;gap:12px;padding:10px 12px;transition:background .2s;display:flex}.analytics-topic-row:hover{background:var(--bg-card-hover)}.analytics-topic-rank{text-align:center;width:28px;font-size:1.1rem}.analytics-topic-info{flex:1}.analytics-topic-name{font-size:.9rem;font-weight:600}.analytics-topic-course{color:var(--text-muted);font-size:.75rem}.analytics-topic-accuracy{text-align:right;min-width:48px;font-size:1rem;font-weight:700}.analytics-topic-detail{color:var(--text-muted);text-align:right;min-width:40px;font-size:.8rem}.analytics-heatmap{grid-template-columns:repeat(18,1fr);gap:3px;display:grid}.analytics-heatmap-cell{aspect-ratio:1;background:var(--bg-deep);border:1px solid var(--border);border-radius:3px;transition:background .2s}.analytics-heatmap-cell.active{background:var(--green);border-color:var(--green);box-shadow:0 0 4px var(--green-glow)}.analytics-heatmap-legend{color:var(--text-muted);justify-content:flex-end;align-items:center;gap:6px;margin-top:8px;font-size:.75rem;display:flex}.analytics-heatmap-legend .analytics-heatmap-cell{width:14px;height:14px;aspect-ratio:unset}.drill-ready-card,.drill-done-card{text-align:center;padding:48px 32px}.drill-ready-icon,.drill-done-icon{margin-bottom:16px;font-size:4rem}.drill-ready-desc{color:var(--text-secondary);max-width:440px;margin:0 auto 24px;font-size:.95rem;line-height:1.5}.drill-high-score-display{color:var(--amber);margin-bottom:24px;font-size:.9rem}.drill-start-btn{align-items:center;gap:8px;font-size:1.1rem;display:inline-flex;padding:12px 32px!important}.drill-new-record{color:var(--amber);margin-bottom:8px;font-size:1.2rem;font-weight:700;animation:.6s infinite alternate pulse}.drill-timer-bar{background:var(--bg-deep);border-radius:3px;height:6px;margin-bottom:4px;overflow:hidden}.drill-timer-fill{border-radius:3px;height:100%;transition:width 1s linear,background .3s}.drill-hud{justify-content:space-between;align-items:center;padding:8px 0;display:flex}.drill-hud-score{gap:16px;font-size:1rem;font-weight:700;display:flex}.drill-hud-timer{color:var(--text-primary);font-family:JetBrains Mono,monospace;font-size:1.8rem;font-weight:800;transition:color .3s}.drill-hud-timer.urgent{color:var(--red);animation:.5s infinite alternate pulse}.drill-playing{transition:background .15s}.drill-flash-correct{background:#4ade800f!important}.drill-flash-wrong{background:#f871710f!important}@media (max-width:768px){.analytics-course-row{flex-direction:column;align-items:flex-start;gap:8px}.analytics-course-label{min-width:unset}.analytics-bar-container{width:100%}.analytics-bar-label{min-width:unset;font-size:.75rem}.analytics-heatmap{grid-template-columns:repeat(10,1fr)}.drill-ready-card,.drill-done-card{padding:32px 16px}.drill-hud-timer{font-size:1.4rem}}@media (max-width:480px){.analytics-heatmap{grid-template-columns:repeat(7,1fr)}.analytics-topic-row{flex-wrap:wrap;gap:6px}.analytics-topic-accuracy{min-width:unset}}.auth-card{text-align:center;max-width:440px;margin:0 auto;padding:48px 40px}.auth-icon{margin-bottom:12px;font-size:3rem}.auth-subtitle{color:var(--text-secondary);margin-bottom:32px;font-size:.9rem;line-height:1.5}.auth-form{text-align:left;flex-direction:column;gap:20px;display:flex}.auth-field label{color:var(--text-secondary);margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.auth-field input{border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-deep);width:100%;color:var(--text-primary);box-sizing:border-box;padding:10px 14px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.auth-field input:focus{border-color:var(--green);box-shadow:0 0 0 2px var(--green-glow);outline:none}.auth-password-wrapper{position:relative}.auth-password-wrapper input{padding-right:40px}.auth-password-toggle{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:4px;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.auth-password-rules{flex-direction:column;gap:4px;margin-top:8px;display:flex}.auth-rule{align-items:center;gap:6px;font-size:.8rem;display:flex}.auth-rule.pass{color:var(--green)}.auth-rule.fail{color:var(--text-muted)}.auth-error{color:var(--red);border-radius:var(--radius-sm);background:#ef44441a;border:1px solid #ef44444d;padding:10px 14px;font-size:.85rem}.auth-submit{justify-content:center;align-items:center;gap:8px;width:100%;margin-top:8px;font-size:1rem;display:flex;padding:12px!important}.auth-footer{color:var(--text-muted);margin-top:24px;font-size:.9rem}.auth-link{color:var(--green);font-weight:600;text-decoration:none}.auth-link:hover{text-decoration:underline}.save-progress-banner{border:1px solid var(--green);border-radius:var(--radius-md);background:#4ade800d;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;padding:16px 20px;display:flex}.save-progress-content{align-items:center;gap:12px;display:flex}.save-progress-icon{font-size:1.5rem}.save-progress-desc{color:var(--text-secondary);margin-top:2px;font-size:.85rem;display:block}.navbar-user-menu{position:relative}.navbar-user-btn{cursor:pointer;background:0 0;font-family:inherit}.navbar-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);z-index:100;min-width:180px;position:absolute;top:calc(100% + 8px);right:0;overflow:visible;box-shadow:0 8px 24px #0006}.navbar-dropdown:before{content:"";background:0 0;height:10px;position:absolute;top:-10px;left:0;right:0}.navbar-dropdown-header{color:var(--green);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding:10px 14px;font-size:.8rem;font-weight:600;display:flex}.navbar-dropdown-item{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;align-items:center;gap:8px;width:100%;padding:10px 14px;font-family:inherit;font-size:.85rem;text-decoration:none;transition:background .15s;display:flex}.navbar-dropdown-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}@media (max-width:768px){.auth-card{padding:32px 20px}.save-progress-banner,.save-progress-content{text-align:center;flex-direction:column}.navbar-dropdown{right:-20px}}.lb-tabs{gap:8px;margin-bottom:20px;display:flex}.lb-tab{border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;padding:10px 20px;font-family:inherit;font-size:.9rem;font-weight:600;transition:all .2s}.lb-tab:hover{background:var(--bg-card-hover);color:var(--text-primary)}.lb-tab.active{background:var(--green);color:var(--bg-deep);border-color:var(--green)}.lb-card{padding:0;overflow:hidden}.lb-table{flex-direction:column;display:flex}.lb-row{border-bottom:1px solid var(--border);align-items:center;padding:14px 20px;transition:background .15s;display:flex}.lb-row:last-child{border-bottom:none}.lb-row:hover{background:var(--bg-card-hover)}.lb-header{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);background:var(--bg-deep);font-size:.8rem;font-weight:700}.lb-header:hover{background:var(--bg-deep)}.lb-col-rank{text-align:center;flex-shrink:0;width:60px}.lb-col-name{flex:1;align-items:center;gap:8px;font-weight:600;display:flex}.lb-col-xp{text-align:right;width:120px;color:var(--green);flex-shrink:0;font-weight:700}.rank-icon{vertical-align:middle}.rank-icon.gold{color:#fbbf24;filter:drop-shadow(0 0 4px #fbbf2466)}.rank-icon.silver{color:#94a3b8;filter:drop-shadow(0 0 4px #94a3b84d)}.rank-icon.bronze{color:#d97706;filter:drop-shadow(0 0 4px #d977064d)}.rank-number{color:var(--text-muted);font-size:.9rem;font-weight:600}.lb-top-1{background:#fbbf240f}.lb-top-2{background:#94a3b80a}.lb-top-3{background:#d977060a}.lb-current-user{border-left:3px solid var(--green);background:#4ade8014!important}.lb-you-badge{background:var(--green);color:var(--bg-deep);text-transform:uppercase;letter-spacing:.05em;border-radius:4px;padding:2px 6px;font-size:.65rem;font-weight:700}.lb-loading,.lb-empty{text-align:center;color:var(--text-secondary);padding:48px 20px;font-size:1rem}.lb-empty p{margin-bottom:8px}@media (max-width:768px){.lb-tabs{flex-wrap:wrap}.lb-tab{text-align:center;flex:1;padding:8px 12px;font-size:.8rem}.lb-col-xp{width:80px;font-size:.85rem}.lb-row{padding:10px 14px}}
